Added all the files from kiwipycon and the changes made for SciPy.in.
authorMadhusudan.C.S <madhusudancs@gmail.com>
Fri, 30 Oct 2009 15:09:12 +0530
changeset 1 fda1c66b25f9
parent 0 9a77edda77b7
child 2 5d9dfa859761
Added all the files from kiwipycon and the changes made for SciPy.in.
AUTHORS
CHANGES
README
TODO
bootstrap.py
buildout.cfg
development.cfg
downloads/django-1.0.tar.gz
downloads/django-1.1.tar.gz
production.cfg
project.db
project/__init__.py
project/development.py
project/kiwipycon/__init__.py
project/kiwipycon/context_processors.py
project/kiwipycon/registration/__init__.py
project/kiwipycon/registration/admin.py
project/kiwipycon/registration/forms.py
project/kiwipycon/registration/labels.py
project/kiwipycon/registration/migrations/0001_initial.py
project/kiwipycon/registration/migrations/0002_create_wifi.py
project/kiwipycon/registration/migrations/__init__.py
project/kiwipycon/registration/models.py
project/kiwipycon/registration/pdf.py
project/kiwipycon/registration/tests.py
project/kiwipycon/registration/utils.py
project/kiwipycon/registration/views.py
project/kiwipycon/sponsor/__init__.py
project/kiwipycon/sponsor/admin.py
project/kiwipycon/sponsor/migrations/0001_initial.py
project/kiwipycon/sponsor/migrations/__init__.py
project/kiwipycon/sponsor/models.py
project/kiwipycon/sponsor/views.py
project/kiwipycon/talk/__init__.py
project/kiwipycon/talk/admin.py
project/kiwipycon/talk/forms.py
project/kiwipycon/talk/migrations/0001_initial.py
project/kiwipycon/talk/migrations/__init__.py
project/kiwipycon/talk/models.py
project/kiwipycon/talk/templatetags/__init__.py
project/kiwipycon/talk/templatetags/talk_extras.py
project/kiwipycon/talk/views.py
project/kiwipycon/user/__init__.py
project/kiwipycon/user/admin.py
project/kiwipycon/user/forms.py
project/kiwipycon/user/migrations/0001_initial.py
project/kiwipycon/user/migrations/__init__.py
project/kiwipycon/user/models.py
project/kiwipycon/user/utils.py
project/kiwipycon/user/views.py
project/kiwipycon/utils.py
project/production.py
project/settings.py
project/setup.py
project/static/admin_media
project/static/css/styles-20090809.css
project/static/css/styles-20090826.css
project/static/css/styles.css
project/static/doc/Kiwi PyCon Media Statement 2.doc
project/static/doc/Kiwi PyCon Media Statement.doc
project/static/img/apress.png
project/static/img/bliptv.gif
project/static/img/canonical.png
project/static/img/catalyst.png
project/static/img/encode.png
project/static/img/favicon.ico
project/static/img/flickr.png
project/static/img/logo-s.png
project/static/img/logo.jpg
project/static/img/logo.png
project/static/img/oreilly.png
project/static/img/packt.png
project/static/img/plone.png
project/static/img/powerhouse.png
project/static/img/pretaweb.png
project/static/img/psf.png
project/static/img/scipyshiny_small.png
project/static/img/slideshare.png
project/static/img/tait.png
project/static/img/twitter.png
project/static/img/unfold.png
project/static/img/user-default.png
project/static/img/vortex.png
project/static/img/webstock.png
project/static/img/weta.jpg
project/static/jquery/jquery.cookie.pack.js
project/static/jquery/jquery.jgrowl.css
project/static/jquery/jquery.jgrowl_minimized.js
project/static/jquery/jquery.pack.js
project/static/js/kiwipycon.js
project/static/pdf/Kiwi PyCon Media Statement 2.pdf
project/static/pdf/Kiwi PyCon Media Statement.pdf
project/static/pdf/Kiwi PyCon Preconference Release.pdf
project/static/pdf/KiwiPyCon09_Sponsorship_Brochure_v1.0.pdf
project/static/pdf/KiwiPyCon09_Sponsorship_Brochure_v1.1.pdf
project/static/pdf/KiwiPyConCfP.pdf
project/templates/404.html
project/templates/500.html
project/templates/_errors.html
project/templates/_menu.html
project/templates/_menu_user.html
project/templates/_sponsors.html
project/templates/about/accommodation.html
project/templates/about/food.html
project/templates/about/reaching.html
project/templates/about/venue.html
project/templates/admin/base_site.html
project/templates/base.html
project/templates/blog/post_detail.html
project/templates/blog/post_list.html
project/templates/comments/form.html
project/templates/flatpages/default.html
project/templates/flatpages/markdown.html
project/templates/flatpages/restructuredtext.html
project/templates/flatpages/textile.html
project/templates/notifications/activate_mail.html
project/templates/registration/download-csv.html
project/templates/registration/edit-registration.html
project/templates/registration/invoice.html
project/templates/registration/registrations.html
project/templates/registration/submit-registration.html
project/templates/sponsor/schwag.html
project/templates/talk/edit-talk.html
project/templates/talk/schedule.html
project/templates/talk/submit-talk.html
project/templates/talk/talk_detail.html
project/templates/talk/talk_list.html
project/templates/talk/talks-cfp.html
project/templates/user/_usermenu.html
project/templates/user/account.html
project/templates/user/editprofile.html
project/templates/user/login.html
project/templates/user/password.html
project/templates/user/username.html
project/urls.py
scripts/scipy_migrate.py
sponsor.sql
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/AUTHORS	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,8 @@
+Marek Kuziel <marek@kuziel.info>
+
+- provided the start up of the project and fixes to Darryl's code.
+
+Darryl Cousins <darryljcousins@gmail.com>
+
+- keeps throwing chunks of code at the project to the demands of Tim.
+- is responsible for the mess and lack of tests
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/CHANGES	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,27 @@
+6 September 2009
+----------------
+
+- added sponsor table, prepopulate from sponsor.sql
+  (need to manually add number of guests allowed per sponsor)
+- sponsor logo and credits sourced from sponsor table
+- new schwag sponsor page (generated from sponsor table)
+  (please delete current static page which this replaces)
+- added fields to registration:
+    party - pre-conference party
+    discount - student/benefits
+    sponsor - a guest of sponsor
+    postcode
+- prefixed invoice number with NZPYCON2009_****
+- added confirmation email for sponsor guests (no invoice number)
+- added payment confirmation email when admin confirms payment for 
+  registrant. (Using save() hook on Registration model
+  PDF invoice will be attached to this email.
+- link and icon to twitter account
+- removed 'submit-talk' links
+- decided that a mechanism to email all speakers or all attendees to be
+  overkill. 
+
+- added list and singleton views for talks
+- set up south migrations for apps
+
+- added further functionality to registrations to deal with price scale.
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/README	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,39 @@
+README
+======
+
+Prerequisites for Linux
+-----------------------
+
+Following software is required:
+
+* Mercurial (easy_install Mercurial)
+* git
+
+Prerequisites for Windows
+-------------------------
+
+Following software is required:
+
+* TortoiseHG
+* msysGit
+
+Quick Install:
+--------------
+
+cd ~/projects/
+hg clone https://vshivak@bitbucket.org/vshivak/kiwipycon/ kiwipycon
+cd kiwipycon
+python bootstrap.py
+./bin/buildout -v -c development.cfg
+./bin/django runserver_plus 8022
+
+# A WSGI web server should be running on your box at this point.
+# Open a web browser and go to URL http://localhost:8022/
+# to see your development version of http://nz.pycon.org/
+
+Sponsor data:
+-------------
+
+Sponsor data can imported into development db.:
+
+cat sponsor.sql | sqlite3 project.db
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/TODO	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,13 @@
+TODO
+====
+- Fix blog CSS
+
+STAGE2
+======
+- kiwipycon/conference (don't add until we release site with call for papers)
+  - models (Resistration)
+  - the nzpug incorporated soc a/c
+
+PERPETUAL
+=========
+- Unittests
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/bootstrap.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,77 @@
+##############################################################################
+#
+# Copyright (c) 2006 Zope Corporation and Contributors.
+# All Rights Reserved.
+#
+# This software is subject to the provisions of the Zope Public License,
+# Version 2.1 (ZPL).  A copy of the ZPL should accompany this distribution.
+# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
+# WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+# WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
+# FOR A PARTICULAR PURPOSE.
+#
+##############################################################################
+"""Bootstrap a buildout-based project
+
+Simply run this script in a directory containing a buildout.cfg.
+The script accepts buildout command-line options, so you can
+use the -c option to specify an alternate configuration file.
+
+$Id$
+"""
+
+import os, shutil, sys, tempfile, urllib2
+
+tmpeggs = tempfile.mkdtemp()
+
+is_jython = sys.platform.startswith('java')
+
+try:
+    import pkg_resources
+except ImportError:
+    ez = {}
+    exec urllib2.urlopen('http://peak.telecommunity.com/dist/ez_setup.py'
+                         ).read() in ez
+    ez['use_setuptools'](to_dir=tmpeggs, download_delay=0)
+
+    import pkg_resources
+
+if sys.platform == 'win32':
+    def quote(c):
+        if ' ' in c:
+            return '"%s"' % c # work around spawn lamosity on windows
+        else:
+            return c
+else:
+    def quote (c):
+        return c
+
+cmd = 'from setuptools.command.easy_install import main; main()'
+ws  = pkg_resources.working_set
+
+if is_jython:
+    import subprocess
+    
+    assert subprocess.Popen([sys.executable] + ['-c', quote(cmd), '-mqNxd', 
+           quote(tmpeggs), 'zc.buildout'], 
+           env=dict(os.environ,
+               PYTHONPATH=
+               ws.find(pkg_resources.Requirement.parse('setuptools')).location
+               ),
+           ).wait() == 0
+
+else:
+    assert os.spawnle(
+        os.P_WAIT, sys.executable, quote (sys.executable),
+        '-c', quote (cmd), '-mqNxd', quote (tmpeggs), 'zc.buildout',
+        dict(os.environ,
+            PYTHONPATH=
+            ws.find(pkg_resources.Requirement.parse('setuptools')).location
+            ),
+        ) == 0
+
+ws.add_entry(tmpeggs)
+ws.require('zc.buildout')
+import zc.buildout.buildout
+zc.buildout.buildout.main(sys.argv[1:] + ['bootstrap'])
+shutil.rmtree(tmpeggs)
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/buildout.cfg	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,74 @@
+[buildout]
+extensions = jarn.setuptoolsfixer
+
+find-links =
+    http://effbot.org/downloads
+    http://dist.repoze.org/
+
+parts =
+    django
+    basic-apps
+    tagging
+    django-command-extensions
+    south
+    registration
+   reportlab
+
+eggs =
+    PIL
+    HTML5lib
+    pisa
+    Werkzeug
+    elementtree
+    docutils
+    markdown
+    textile
+    beautifulsoup
+
+[versions]
+reportlab=2.3
+
+[reportlab]
+recipe=zc.recipe.egg
+eggs=
+    reportlab
+find-links=
+    http://distfiles.minitage.org/public/externals/minitage/
+
+[django]
+recipe = djangorecipe
+version = 1.1
+settings = production
+eggs =
+    ${buildout:eggs}
+    ${reportlab:eggs}
+pythonpath =
+    ${basic-apps:location}
+    ${tagging:location}
+    ${django-command-extensions:location}
+    ${south:location}
+    ${registration:location}
+
+[basic-apps]
+recipe = infrae.subversion
+urls =
+    http://django-basic-apps.googlecode.com/svn/trunk/ basic
+
+[tagging]
+recipe = infrae.subversion
+urls =
+    http://django-tagging.googlecode.com/svn/trunk/ .
+
+[django-command-extensions]
+recipe = zerokspot.recipe.git
+repository = http://github.com/django-extensions/django-extensions.git
+
+[south]
+recipe = infrae.subversion
+urls =
+    http://svn.aeracode.org/svn/south/tags/0.5/ .
+
+[registration]
+recipe = mercurialrecipe
+repository = http://bitbucket.org/ubernostrum/django-registration/
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/development.cfg	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,10 @@
+[buildout]
+extends =
+    buildout.cfg
+
+eggs +=
+    pysqlite
+
+[django]
+settings = development
+eggs = ${buildout:eggs}
Binary file downloads/django-1.1.tar.gz has changed
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/production.cfg	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,6 @@
+[buildout]
+extends =
+    buildout.cfg
+
+eggs +=
+    psycopg2
Binary file project.db has changed
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/__init__.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,1 @@
+# make me a package
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/development.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,41 @@
+#django
+from project.settings import *
+
+DEBUG=True
+TEMPLATE_DEBUG=DEBUG
+
+SITE_ID = 1
+
+INSTALLED_APPS = (
+    'django.contrib.auth',
+    'django.contrib.contenttypes',
+    'django.contrib.comments',
+    'django.contrib.sessions',
+    'django.contrib.admin',
+    'django.contrib.sites',
+    'django.contrib.flatpages',
+    'django.contrib.markup',
+    'project.kiwipycon',
+    'project.kiwipycon.user',
+    'project.kiwipycon.talk',
+    'project.kiwipycon.registration',
+    'project.kiwipycon.sponsor',
+    'tagging',
+    'basic.blog',
+    'basic.inlines',
+    'basic.media',
+    'django_extensions',
+    'south',
+    'registration',
+)
+
+DATABASE_ENGINE = 'mysql'
+DATABASE_NAME = 'conference'
+DATABASE_USER = ''
+DATABASE_PASSWORD = ''
+
+EMAIL_HOST = 'localhost'
+EMAIL_PORT = '1025'
+# print to standard output:
+# python -m smtpd -n -c DebuggingServer localhost:1025
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/context_processors.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,17 @@
+from datetime import datetime
+
+from django.conf import settings
+
+from project.kiwipycon.sponsor.models import Sponsor
+
+def sponsors(request):
+    sponsors = Sponsor.objects.all()
+    gold_sponsors = sponsors.filter(type='gold')
+    silver_sponsors = sponsors.filter(type='silver')
+    schwag_sponsors = sponsors.filter(type='schwag')
+    return {
+            'sponsors': {'gold': gold_sponsors,
+                         'silver': silver_sponsors,
+                         'schwag': schwag_sponsors}
+    }
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/registration/admin.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,37 @@
+# -*- coding: utf-8 -*-
+from __future__ import absolute_import
+
+#django.contrib
+from django.contrib import admin
+
+#kiwipycon
+from .models import Registration
+from .models import Wifi
+
+class RegistrationAdmin(admin.ModelAdmin):
+    list_display = ('registrant', 'slug', 'email', 'city', 
+            'organisation', 'occupation', 'postcode',
+            'tshirt', 'conference', 'tutorial', 'sprint',
+            'allow_contact')
+    fieldsets = (
+        ('Details', {
+            'fields': ('slug', 'registrant', 'organisation', 'occupation',
+                'city', 'tshirt')
+        }),
+        ('Information', {
+            'fields': ('allow_contact',),
+        }),
+    )
+
+    def email(self, obj):
+        return obj.registrant.email
+
+
+admin.site.register(Registration, RegistrationAdmin)
+
+class WifiAdmin(admin.ModelAdmin):
+    list_display = ('user', 'wifi',)
+    list_filter = ('wifi',)
+
+admin.site.register(Wifi, WifiAdmin)
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/registration/forms.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,179 @@
+# -*- coding: utf-8 -*-
+from __future__ import absolute_import
+
+#django
+from django import forms
+from django.core.exceptions import ObjectDoesNotExist
+
+#django.contrib
+from django.contrib.auth.models import User
+
+from .models import SIZE_CHOICES
+from .models import Registration
+from .models import Wifi
+from project.kiwipycon.sponsor.models import Sponsor
+
+class RegistrationSubmitForm(forms.Form):
+    """PyCon registration form
+    """
+    tshirt = forms.ChoiceField(choices=SIZE_CHOICES, required=True,
+        label=u'T-shirt size', help_text=u'Yes, we all get a t-shirt!')
+#    beverage = forms.CharField(required=True, label=u'Beverage',
+#        help_text=u'Your beverage of choice - coffee, tea etc',
+#        max_length=255,
+#        widget=forms.TextInput(attrs={'size':'50'}))
+#    diet = forms.CharField(required=False, label=u'Dietary',
+#        help_text=u'Special dietary requirements - vegetarian etc',
+#        max_length=255,
+#        widget=forms.TextInput(attrs={'size':'50'}))
+    organisation = forms.CharField(required=True, label=u'Organisation',
+        help_text=u'The primary organisation that you are a member of.',
+        max_length=255,
+        widget=forms.TextInput(attrs={'size':'50'}))
+    occupation = forms.CharField(required=True, label=u'Occupation',
+        help_text=u'Title of your occupation',
+        max_length=255,
+        widget=forms.TextInput(attrs={'size':'50'}))
+    city = forms.CharField(required=True, label=u'City',
+        help_text=u'City of residence',
+        max_length=255,
+        widget=forms.TextInput(attrs={'size':'50'}))
+    postcode = forms.CharField(required=False, label=u'Postcode',
+        help_text=u'This field is optional',
+        max_length=10,
+        widget=forms.TextInput(attrs={'size':'10'}))
+    allow_contact = forms.BooleanField(required=False, label=u'Contact',
+        help_text=u'May organizers of SciPy.in contact you after the event?')
+    conference = forms.BooleanField(required=False, label=u'Conference',
+        help_text=u"""Do you intend to attend the SciPy conference?  
+        Note: Only conference has an registration fee of Rs.200 which you will
+        pay on the spot.""")
+    tutorial = forms.BooleanField(required=False, label=u'Tutorial',
+        help_text=u'Do you intend to attend the tutorials?')
+    sprint = forms.BooleanField(required=False, label=u'Sprint',
+        help_text=u'Do you intend to attend the sprints?')
+#    party = forms.BooleanField(required=False, label=u'Pre-con party',
+#        help_text=u'Do you intend to attend the pre-conference party on Friday?')
+#    discount = forms.BooleanField(required=False, label=u'Student/Unwaged?',
+#        help_text=u'You will be required to present your Community Services '\
+#                'Card or Student ID on arrival.')
+#    sponsor = forms.CharField(required=False, label=u'Sponsor code',
+#        help_text=u'If attending as a sponsor please enter your sponsor code.',
+#        max_length=50,
+#        widget=forms.TextInput(attrs={'size':'20'}))
+
+    def demographic_fields(self):
+        return (self['organisation'],
+                self['occupation'],
+                self['city'],
+                self['postcode'])
+
+    def personal_fields(self):
+        return (self['tshirt'],
+                self['conference'],
+                self['tutorial'],
+                self['sprint'],
+                self['allow_contact'])
+
+#    def other_fields(self):
+#        return (self['sponsor'],)
+#
+#    def clean_sponsor(self):
+#        """Validates that the entered sponsor code is valid and within limits
+#        of allowed guests
+#        """
+#        sponsorcode = self.cleaned_data.get("sponsor")
+#        if sponsorcode:
+#            try:
+#                sponsor = Sponsor.objects.get(slug=sponsorcode)
+#            except ObjectDoesNotExist:
+#                raise forms.ValidationError(
+#                    u"The sponsor code you entered is not valid.")
+#            if sponsor:
+#                guests = sponsor.guests
+#                if guests == 0:
+#                    raise forms.ValidationError(
+#                        u"The sponsor code you entered is not valid.")
+#                count = Registration.objects.filter(
+#                            sponsor=sponsorcode).count()
+#                if count >= guests:
+#                    raise forms.ValidationError(
+#                    u"That sponsor has reached limit of guests.")
+#
+#
+#        return sponsorcode
+
+
+class RegistrationEditForm(RegistrationSubmitForm):
+    id = forms.CharField(widget=forms.HiddenInput)
+    sponsor = forms.CharField(required=False, widget=forms.HiddenInput)
+
+class WifiForm(forms.ModelForm):
+    """PyCon wifi form
+    """
+
+    def save(self, user):
+        wifi = Wifi(user=user, wifi=self.cleaned_data['wifi'])
+        wifi.save()
+        return wifi
+
+    class Meta:
+        model = Wifi
+        fields = ('wifi',)
+
+PC = (
+        ('all', 'all'),
+        ('paid', 'paid'),
+        ('not paid', 'not paid')
+        )
+HC = (
+        ('all', 'all'),
+        ('party', 'party'),
+        ('no party', 'no party')
+        )
+AC = (
+        ('all', 'all'),
+        ('0', '0'),
+        ('10', '10'),
+        ('20', '20'),
+        ('40', '40'),
+        )
+OC = (
+        ('email', 'email'),
+        ('amount', 'amount'),
+        )
+
+IC = (
+        ('Name', 'name'),
+        ('Email', 'email'),
+        ('Amount', 'amount'),
+        ('Organisation', 'organisation'),
+        ('Conference', 'conference'),
+        ('Tutorial', 'tutorial'),
+        ('Sprint', 'sprint'),
+        ('T-size', 'tshirt'),
+        )
+
+SC = (
+    ('all', 'all'),
+    ('S', 'S'),
+    ('M', 'M'),
+    ('L', 'L'),
+    ('XL', 'XL'),
+    )
+class RegistrationAdminSelectForm(forms.Form):
+    """
+    Used to make selection for csv download
+    """
+    by_payment = forms.ChoiceField(choices=PC, required=False,
+        label=u'By payment')
+    by_amount = forms.MultipleChoiceField(choices=AC, required=False,
+        label=u'By amount')
+    by_party = forms.ChoiceField(choices=HC, required=False,
+        label=u'by party')
+    by_tshirt = forms.ChoiceField(choices=SC, required=False,
+        label=u'by tshirt size')
+    order_by = forms.ChoiceField(choices=OC, required=False,
+        label=u'order results')
+    include = forms.MultipleChoiceField(choices=IC, required=False,
+        label=u'Include fields')
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/registration/labels.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,7 @@
+
+WIFI_CHOICES = (
+    ("0", "Yes"),
+    ('1', 'No'),
+    )
+
+WIFI_HELP = """Are you bringing a laptop to the event?"""
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/registration/migrations/0001_initial.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,70 @@
+# -*- coding: utf-8 -*-
+
+from south.db import db
+from django.db import models
+from project.kiwipycon.registration.models import *
+
+class Migration:
+    
+    def forwards(self, orm):
+        
+        # Adding model 'Registration'
+        db.create_table('registration_registration', (
+            ('city', models.CharField(max_length=255, blank=True)),
+            ('slug', models.SlugField()),
+            ('submitted', models.DateTimeField(auto_now_add=True)),
+            ('allow_contact', models.BooleanField(default=False)),
+            ('last_mod', models.DateTimeField(auto_now=True)),
+            ('payment', models.BooleanField(default=False)),
+            ('organisation', models.CharField(max_length=255, blank=True)),
+            ('diet', models.CharField(max_length=255, blank=True)),
+            ('id', models.AutoField(primary_key=True)),
+            ('sponsor', models.CharField(max_length=255, blank=True)),
+            ('discount', models.BooleanField(default=False)),
+            ('amount', models.IntegerField(default=0)),
+            ('tshirt', models.CharField(max_length=2)),
+            ('beverage', models.CharField(max_length=255, blank=True)),
+            ('postcode', models.CharField(max_length=255, blank=True)),
+            ('party', models.BooleanField(default=False)),
+            ('registrant', models.ForeignKey(orm['auth.User'])),
+            ('occupation', models.CharField(max_length=255, blank=True)),
+        ))
+        db.send_create_signal('registration', ['Registration'])
+        
+    
+    
+    def backwards(self, orm):
+        
+        # Deleting model 'Registration'
+        db.delete_table('registration_registration')
+        
+    
+    
+    models = {
+        'auth.user': {
+            '_stub': True,
+            'id': ('models.AutoField', [], {'primary_key': 'True'})
+        },
+        'registration.registration': {
+            'allow_contact': ('models.BooleanField', [], {'default': 'False'}),
+            'beverage': ('models.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'city': ('models.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'diet': ('models.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'discount': ('models.BooleanField', [], {'default': 'False'}),
+            'amount': ('models.IntegerField', [], {'default': 0}),
+            'id': ('models.AutoField', [], {'primary_key': 'True'}),
+            'last_mod': ('models.DateTimeField', [], {'auto_now': 'True'}),
+            'occupation': ('models.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'organisation': ('models.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'party': ('models.BooleanField', [], {'default': 'False'}),
+            'payment': ('models.BooleanField', [], {'default': 'False'}),
+            'postcode': ('models.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'registrant': ('models.ForeignKey', ['User'], {}),
+            'slug': ('models.SlugField', [], {}),
+            'sponsor': ('models.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'submitted': ('models.DateTimeField', [], {'auto_now_add': 'True'}),
+            'tshirt': ('models.CharField', [], {'max_length': '2'})
+        }
+    }
+    
+    complete_apps = ['registration']
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/registration/migrations/0002_create_wifi.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,60 @@
+# -*- coding: utf-8 -*-
+
+from south.db import db
+from django.db import models
+from project.kiwipycon.registration.models import *
+
+class Migration:
+    
+    def forwards(self, orm):
+        
+        # Adding model 'Wifi'
+        db.create_table('registration_wifi', (
+            ('wifi', models.CharField(max_length=50)),
+            ('user', models.ForeignKey(orm['auth.User'])),
+            ('id', models.AutoField(primary_key=True)),
+        ))
+        db.send_create_signal('registration', ['Wifi'])
+        
+    
+    
+    def backwards(self, orm):
+        
+        # Deleting model 'Wifi'
+        db.delete_table('registration_wifi')
+        
+    
+    
+    models = {
+        'auth.user': {
+            '_stub': True,
+            'id': ('models.AutoField', [], {'primary_key': 'True'})
+        },
+        'registration.wifi': {
+            'id': ('models.AutoField', [], {'primary_key': 'True'}),
+            'user': ('models.ForeignKey', ['User'], {}),
+            'wifi': ('models.CharField', [], {'max_length': '50'})
+        },
+        'registration.registration': {
+            'allow_contact': ('models.BooleanField', [], {'default': 'False'}),
+            'amount': ('models.IntegerField', [], {'default': '0'}),
+            'beverage': ('models.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'city': ('models.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'diet': ('models.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'discount': ('models.BooleanField', [], {'default': 'False'}),
+            'id': ('models.AutoField', [], {'primary_key': 'True'}),
+            'last_mod': ('models.DateTimeField', [], {'auto_now': 'True'}),
+            'occupation': ('models.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'organisation': ('models.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'party': ('models.BooleanField', [], {'default': 'False'}),
+            'payment': ('models.BooleanField', [], {'default': 'False'}),
+            'postcode': ('models.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'registrant': ('models.ForeignKey', ['User'], {}),
+            'slug': ('models.SlugField', [], {}),
+            'sponsor': ('models.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'submitted': ('models.DateTimeField', [], {'auto_now_add': 'True'}),
+            'tshirt': ('models.CharField', [], {'max_length': '2'})
+        }
+    }
+    
+    complete_apps = ['registration']
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/registration/models.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,68 @@
+# -*- coding: utf-8 -*-
+from __future__ import absolute_import
+
+#django
+from django.db import models
+from django.contrib.auth.models import User
+
+from .utils import send_confirmation_payment_email
+from .utils import send_banking_fix_email
+
+from .labels import WIFI_CHOICES
+from .labels import WIFI_HELP
+
+SIZE_CHOICES = (
+    ('S', 'S'),
+    ('M', 'M'),
+    ('L', 'L'),
+    ('XL', 'XL'),
+    )
+
+class Wifi(models.Model):
+    """Defines wifi options at *PyCon"""
+    user = models.ForeignKey(User)
+    wifi = models.CharField(max_length=50, choices=WIFI_CHOICES,
+            help_text=WIFI_HELP, verbose_name="Laptop")
+
+class Registration(models.Model):
+    """Defines registration at *PyCon"""
+    slug = models.SlugField()
+    registrant = models.ForeignKey(User)
+    organisation = models.CharField(max_length=255, blank=True)
+    occupation = models.CharField(max_length=255, blank=True)
+    city = models.CharField(max_length=255, blank=True)
+    postcode = models.CharField(max_length=255, blank=True)
+#    beverage = models.CharField(max_length=255, blank=True)
+#    diet = models.CharField(max_length=255, blank=True)
+#    sponsor = models.CharField(max_length=255, blank=True)
+    tshirt = models.CharField(max_length=2, choices=SIZE_CHOICES)
+#    party = models.BooleanField(default=False)
+#    discount = models.BooleanField(default=False)
+
+    # scipy.in specific
+    conference = models.BooleanField(default=False)
+    # scipy.in specific
+    tutorial = models.BooleanField(default=False)
+    # scipy.in specific
+    sprint = models.BooleanField(default=False)
+
+    amount = models.IntegerField(default=0)
+    allow_contact = models.BooleanField(default=False)
+#    payment = models.BooleanField(default=False)
+    submitted = models.DateTimeField(auto_now_add=True)
+    last_mod = models.DateTimeField(auto_now=True)
+
+    def __unicode__(self):
+        return 'Registration for user: <%s %s> %s' % (self.registrant.first_name,
+                self.registrant.last_name, self.registrant.email)
+
+#    def save(self, *args, **kwargs):
+#        if(self.id):
+#            old_reg = Registration.objects.get(pk=self.id)
+#            if(old_reg.payment == False and self.payment == True \
+#                    and not self.sponsor):
+#                send_confirmation_payment_email(self.registrant)
+#            if(old_reg.slug.startswith('NZ') and self.slug.startswith('KPC') \
+#                    and not self.sponsor):
+#                send_banking_fix_email(self.registrant, self.slug)
+#        super(Registration, self).save(args, kwargs)
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/registration/pdf.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,20 @@
+import os
+
+from django.conf import settings
+from django.template.loader import render_to_string
+
+def save_invoice(user, registration, template_name):
+    content = render_to_string(template_name,
+        {'registration' : registration, 'user': user})
+    filename = '%s.html' % registration.slug
+    filepath = os.path.join(settings.USER_MEDIA_PDF, filename)
+    save_to_file(content, filepath)
+
+def save_to_pdf(content, filepath):
+    import pisa
+    pisa.CreatePDF(str(content), file(filepath, 'wb'))
+
+def save_to_file(content, filepath):
+    fout = file(filepath, 'wb')
+    fout.write(content)
+    fout.close()
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/registration/tests.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,19 @@
+
+
+def test_save_to_pdf():
+    """
+    >>> from .pdf import save_invoice
+    >>> from django.db.models.loading import get_model
+    >>> userModel =  get_model('auth', 'user')
+    >>> user = userModel(username='joe', email='joe@gmail.com',
+    ...         first_name='Joe', last_name='Bloggs')
+    >>> user.save()
+    >>> regModel =  get_model('registration', 'registration')
+    >>> registration = regModel(registrant=user, amount=40,
+    ...          slug='NZPYCON-0001')
+    >>> registration.save()
+
+    >>> save_invoice(user, registration, 'registration/invoice.html')
+
+    """
+    pass
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/registration/utils.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,215 @@
+# -*- coding: utf-8 -*-
+from __future__ import absolute_import
+
+# django
+from django.core.mail import EmailMessage
+
+def send_confirmation(registrant, invoice, password=None, sponsor=None,
+        amount=None):
+
+    message = EmailMessage()
+    message.subject = u'Registration to SciPy.in 2009'
+    message.from_email = u'admin@scipy.in'
+    message.to = [registrant.email]
+    name = '%s %s' % (registrant.first_name, registrant.last_name)
+    if name.strip() == '':
+        name = registrant.username
+
+    username = registrant.username
+    all = {'name': name,
+            'password': password,
+            'username': username}
+
+    if password:
+        message.body = confirmation_newuser % all
+    else:
+        message.body = confirmation_currentuser % all
+
+    message.send()
+
+def send_confirmation_payment_email(registrant):
+    message = EmailMessage()
+    message.subject = u'Registration payment to SciPy.in 2009'
+    message.from_email = u'admin@scipy.in'
+    message.to = [registrant.email]
+    name = '%s %s' % (registrant.first_name, registrant.last_name)
+    username = registrant.username
+    if name.strip() == '':
+        name = registrant.username
+    message.body = confirmation_payment % dict(name=name,
+            username=username)
+    message.send()
+
+def send_banking_fix_email(registrant, invoicenum):
+    message = EmailMessage()
+    message.subject = u'Registration invoice update to SciPy.in 2009'
+    message.from_email = u'admin@scipy.in'
+    message.to = [registrant.email]
+    name = '%s %s' % (registrant.first_name, registrant.last_name)
+    username = registrant.username
+    if name.strip() == '':
+        name = registrant.username
+    message.body = banking_fix % dict(name=name,
+            username=username, invoice=invoicenum)
+    message.send()
+
+banking_fix = """
+Dear %(name)s,
+
+Invoice update to Kiwi Pycon 2009.
+
+Ooops. We made the invoice number too long to be entered for internet banking.
+We have therefore changed the prefix and your new invoice number is:
+%(invoice)s
+
+You will find that your online invoice has been updated. Thanks for your
+patience.
+
+http://nz.pycon.org/invoice
+A pdf version here:
+http://nz.pycon.org/pdf_invoice
+
+Regards,
+The Kiwi Pycon 2009 Team
+
+Your username, in case you've forgotten: %(username)s.
+
+If you have lost your password to the website please visit:
+http://nz.pycon.org/password-reset
+
+    """
+
+confirmation_payment = """
+Dear %(name)s,
+
+Welcome to Kiwi Pycon 2009.
+
+Your payment has been received and your attendence confirmed.
+
+Many thanks!
+
+You can view your invoice at:
+http://nz.pycon.org/invoice
+And a pdf version here:
+http://nz.pycon.org/pdf_invoice
+
+Regards,
+The Kiwi Pycon 2009 Team
+
+Your username, in case you've forgotten: %(username)s.
+
+If you have lost your password to the website please visit:
+http://nz.pycon.org/password-reset
+
+    """
+
+confirmation_newuser = """
+Dear %(name)s,
+
+Welcome to Kiwi Pycon 2009. You may log in to 
+http://nz.pycon.org/login using the following credentials:
+
+Username: %(username)s
+Password: %(password)s
+
+Amount: %(amount)s
+
+Your invoice number is: %(invoice)s
+
+Please use this number and your username as reference when 
+making payment to the following:
+
+New Zealand Python User Group,
+06-0158-0360348-00
+The National Bank,
+Auckland University Branch
+PO Box 2132
+
+Thanks for your registration!
+
+You can view your invoice at:
+http://nz.pycon.org/invoice
+And a pdf version here:
+http://nz.pycon.org/pdf_invoice
+
+Regards,
+The Kiwi Pycon 2009 Team
+
+If you lose your password to the website please visit:
+http://nz.pycon.org/password-reset
+
+    """
+
+confirmation_sponsoreduser = """
+Dear %(name)s,
+
+Welcome to Kiwi Pycon 2009.
+
+Your username is: %(username)s
+
+Your registration has been accepted as a guest of %(stype)s 
+sponsor %(sname)s.
+
+Thanks!
+
+Regards,
+The Kiwi Pycon 2009 Team
+
+If you have lost your password to the website please visit:
+http://nz.pycon.org/password-reset
+
+    """
+
+confirmation_sponsorednewuser = """
+Dear %(name)s,
+
+Welcome to Kiwi Pycon 2009.
+
+Your username is: %(username)s
+Your password is: %(password)s
+
+Your registration has been accepted as a guest of %(stype)s sponsor %(sname)s.
+
+Thanks!
+
+Regards,
+The Kiwi Pycon 2009 Team
+
+If you lose your password to the website please visit:
+http://nz.pycon.org/password-reset
+
+    """
+
+confirmation_currentuser = """
+Dear %(name)s,
+
+Welcome to Kiwi Pycon 2009.
+
+Your invoice number is: %(invoice)s
+Your username is: %(username)s
+
+Amount: %(amount)s
+
+Please use this number and your username as reference when making payment
+to the following:
+
+New Zealand Python User Group,
+06-0158-0360348-00
+The National Bank,
+Auckland University Branch
+PO Box 2132
+
+Thanks for your registration!
+
+You can view your invoice at:
+http://nz.pycon.org/invoice 
+And a pdf version here:
+http://nz.pycon.org/pdf_invoice
+
+Regards,
+The Kiwi Pycon 2009 Team
+
+If you have lost your password to the website please visit:
+http://nz.pycon.org/password-reset
+
+    """
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/registration/views.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,336 @@
+# -*- coding: utf-8 -*-
+from __future__ import absolute_import
+
+import cStringIO as StringIO
+import csv
+
+# django
+from django.conf import settings
+from django.shortcuts import render_to_response
+from django.template.loader import render_to_string
+from django.shortcuts import get_object_or_404
+from django.template import RequestContext
+from django.core.urlresolvers import reverse
+from django.http import HttpResponse
+
+from django.contrib.auth.decorators import login_required
+from django.contrib.auth.forms import AuthenticationForm
+from django.contrib.auth.models import User
+from django.core.exceptions import ObjectDoesNotExist
+
+#kiwipycon
+from project.kiwipycon.utils import set_message_cookie
+from project.kiwipycon.utils import slugify
+from project.kiwipycon.user.models import UserProfile
+from project.kiwipycon.user.utils import kiwipycon_createregistrant
+from project.kiwipycon.user.forms import RegistrantForm
+from project.kiwipycon.sponsor.models import Sponsor
+from project.kiwipycon.talk.models import Talk
+
+from .models import Registration
+from .models import Wifi
+from .forms import RegistrationSubmitForm
+from .forms import RegistrationEditForm
+from .forms import RegistrationAdminSelectForm
+from .forms import WifiForm
+from .utils import send_confirmation
+
+from .forms import IC
+
+REG_TOTAL = 1000
+
+@login_required
+def download_csv(request,
+        template_name = 'registration/download-csv.html'):
+    """
+    """
+    if not request.user.is_staff:
+        redirect_to = reverse('kiwipycon_login')
+    if request.method == "POST":
+        form = RegistrationAdminSelectForm(request.POST)
+        if form.is_valid():
+            conference = form.cleaned_data['by_conference']
+            tutorial = form.cleaned_data['by_tutorial']
+            sprint = form.cleaned_data['by_sprint']
+            amount = form.cleaned_data['by_amount']
+            tshirt = form.cleaned_data['by_tshirt']
+            order_by = form.cleaned_data['order_by']
+            include = form.cleaned_data['include']
+            q = Registration.objects.all()
+            if conference == 'conference':
+                q = q.filter(conference=True)
+            elif conference == 'no conference':
+                q = q.filter(conference=False)
+            elif tutorial == 'tutorial':
+                q = q.filter(tutorial=True)
+            elif tutorial == 'no tutorial':
+                q = q.filter(tutorial=False)
+            if sprint == 'sprint':
+                q = q.filter(sprint=True)
+            if sprint == 'no sprint':
+                q = q.filter(sprint=False)
+            elif tshirt != 'all':
+                q = q.filter(tshirt=tshirt)
+            q = q.order_by('registrant__email')
+            query = q.query
+            results = list(q)
+            if include == []:
+                # default to include all fields
+                include = [i[0] for i in IC]
+            if results:
+                response = HttpResponse(mimetype='text/csv')
+                response['Content-Disposition'] = 'attachment; filename=registrations.csv'
+                output = csv.writer(response)
+                output.writerow([h for h in include])
+                for row in results:
+                    conference = row.conference == True and 'yes' or 'no'
+                    tutorial = row.tutorial == True and 'yes' or 'no'
+                    sprint = row.sprint == True and 'yes' or 'no'
+                    wrow = []
+                    if 'Name' in include:
+                        wrow.append(
+                            row.registrant.get_full_name().encode('utf-8'))
+                    if 'Email' in include:
+                        wrow.append(row.registrant.email.encode('utf-8'))
+                    if 'Organisation' in include:
+                        wrow.append(row.organisation.encode('utf-8'))
+                    if 'Conference' in include:
+                        wrow.append(conference)
+                    if 'Tutorial' in include:
+                        wrow.append(tutorial)
+                    if 'Sprint' in include:
+                        wrow.append(sprint)
+                    if 'T-size' in include:
+                        wrow.append(row.tshirt)
+                    output.writerow(wrow)
+                return response
+            else:
+                no_results = u'No results found for the query'
+
+    else:
+        form = RegistrationAdminSelectForm()
+    return render_to_response(template_name, RequestContext(request,
+        locals()))
+
+# NOT REQUIRED FOR SciPy.in
+@login_required
+def invoice(request, template_name='registration/invoice.html'):
+    user = request.user
+    registration = get_object_or_404(Registration, registrant=user)
+    if registration.sponsor:
+        redirect_to = reverse('kiwipycon_account')
+        return set_message_cookie(redirect_to,
+                msg = u'You are a sponsored guest, no payment required.')
+    return render_to_response(template_name, RequestContext(request,
+        {'registration' : registration, 'user': user}))
+
+@login_required
+def pdf_invoice(request, template_name='registration/invoice.html'):
+    user = request.user
+    registration = get_object_or_404(Registration, registrant=user)
+    if registration.sponsor:
+        redirect_to = reverse('kiwipycon_account')
+        return set_message_cookie(redirect_to,
+                msg = u'You are a sponsored guest, no payment required.')
+    content = render_to_string(template_name,
+        {'registration' : registration, 'user': user})
+    result = StringIO.StringIO()
+    import ho.pisa
+    pdf = ho.pisa.pisaDocument(StringIO.StringIO(content.encode("UTF-8")),result)
+    if not pdf.err:
+        return HttpResponse(result.getvalue(), mimetype='application/pdf')
+    return HttpResponse("Gremlins ate your invoice, please try html" \
+        " version")
+
+
+def registrations(request,
+        template_name='registration/registrations.html'):
+    """Simple page to count registrations"""
+    #registrations = Registration.objects.filter(payment=True).count()
+    registrations = Registration.objects.all().count()
+    return render_to_response(template_name, RequestContext(request,
+        {
+        'over_reg' : registrations >= REG_TOTAL and True or False,
+            'registrations' : registrations}))
+
+@login_required
+def edit_registration(request, id,
+        template_name='registration/edit-registration.html'):
+    '''Allows users that submitted a registration to edit it.
+    '''
+    reg = Registration.objects.get(pk=id)
+
+    if reg.registrant != request.user:
+        redirect_to = reverse('kiwipycon_account')
+        return set_message_cookie(redirect_to,
+                msg = u'Redirected because the registration you selected' \
+                      + ' is not your own.')
+
+    if request.method == 'POST':
+        form = RegistrationEditForm(data=request.POST)
+        if form.is_valid():
+            reg.organisation = form.data.get('organisation')
+            reg.occupation = form.data.get('occupation')
+            reg.city = form.data.get('city')
+            reg.tshirt = form.data.get('tshirt')
+            reg.allow_contact = form.data.get('allow_contact') and True or False
+            reg.conference = form.data.get('conference') and True or False
+            reg.tutorial = form.data.get('tutorial') and True or False
+            reg.sprint = form.data.get('sprint') and True or False
+            reg.save()
+            # Saved.. redirect
+            redirect_to = reverse('kiwipycon_account')
+            return set_message_cookie(redirect_to,
+                    msg = u'Your changes have been saved.')
+    else:
+        form = RegistrationEditForm(initial={
+                                    'id' : id,
+                                    'organisation' : reg.organisation,
+                                    'occupation' : reg.occupation,
+                                    'city' : reg.city,
+                                    'tshirt' : reg.tshirt,
+                                    'conference': reg.conference,
+                                    'tutorial': reg.tutorial,
+                                    'postcode' : reg.postcode,
+                                    'sprint' : reg.sprint,
+                                    'allow_contact' : reg.allow_contact,
+            })
+
+    return render_to_response(template_name, RequestContext(request, locals()))
+
+def submit_registration(request,
+        template_name='registration/submit-registration.html'):
+    '''Allows user to edit registration
+    '''
+    user = request.user
+    reg_count = Registration.objects.all().count()
+    if user.is_authenticated():
+        try:
+            profile = user.get_profile()
+        except:
+            profile, new = UserProfile.objects.get_or_create(user=user)
+            if new:
+                profile.save()
+        try:
+            registration = Registration.objects.get(registrant=user)
+            if registration:
+                redirect_to = reverse('kiwipycon_account')
+                return set_message_cookie(redirect_to,
+                        msg = u'You have already been registered.')
+
+        except ObjectDoesNotExist:
+            pass
+
+    message = None
+
+    if request.method == 'POST':
+        registration_form = RegistrationSubmitForm(data=request.POST)
+        registrant_form = RegistrantForm(data=request.POST)
+        wifi_form = WifiForm(data=request.POST)
+
+        if request.POST.get('action', None) == 'login':
+            login_form = AuthenticationForm(data=request.POST)
+            if login_form.is_valid():
+
+                from django.contrib.auth import login
+                login(request, login_form.get_user())
+
+                redirect_to = reverse('kiwipycon_submit_registration')
+                return set_message_cookie(redirect_to,
+                        msg = u'You have been logged in please continue' + \
+                               'with registration.')
+
+        newuser = None
+        passwd = None
+        if not user.is_authenticated():
+            if registrant_form.is_valid():
+                newuser = kiwipycon_createregistrant(request, registrant_form.data)
+                # Log in user
+                passwd = User.objects.make_random_password()
+                newuser.set_password(passwd)
+                newuser.save()
+                from django.contrib.auth import authenticate
+                user = authenticate(username=newuser.username, password=passwd)
+
+                from django.contrib.auth import login
+                login(request, user)
+
+                newuser = user
+
+        else:
+            newuser = user
+
+        if registration_form.is_valid() and newuser:
+            allow_contact = registration_form.data.get('allow_contact') and \
+                                        True or False
+            conference = registration_form.data.get('conference') and \
+                                        True or False
+            tutorial = registration_form.data.get('tutorial') and \
+                                        True or False
+            sprint = registration_form.data.get('sprint') and \
+                                        True or False
+
+            registrant = User.objects.get(pk=newuser.id)
+
+            presenter = None
+            talks = Talk.objects.filter(
+                    speaker=registrant).filter(approved=True)
+            if talks:
+                for talk in talks:
+                    if talk.duration == '30':
+                        presenter = True
+                    elif talk.duration == '60':
+                        presenter = True
+            
+            reg = Registration(
+                    #     slug = newuser.username,
+                registrant = registrant,
+                organisation = registration_form.data.get('organisation'),
+                occupation = registration_form.data.get('occupation'),
+                city = registration_form.data.get('city'),
+                tshirt = registration_form.data.get('tshirt'),
+                postcode = registration_form.cleaned_data.get('postcode'),
+                allow_contact = allow_contact,
+                conference = conference,
+                tutorial = tutorial,
+                sprint = sprint)
+            reg.save() 
+
+            # get id and use as slug and invoice number
+            id = reg.id
+            slug = 'KPC09%03d' % id
+            reg.slug = slug
+            reg.save()
+
+            # additional tasks:
+            if wifi_form.is_valid():
+                wifi = wifi_form.save(registrant)
+            
+            # 1. include random password if we are a new user
+            if passwd:
+                send_confirmation(registrant, slug, password=passwd)
+            else:
+            # 2. send user email with registration id
+                send_confirmation(registrant, slug)
+
+            redirect_to = reverse('kiwipycon_registrations')
+            return set_message_cookie(redirect_to,
+                    msg = u'Thank you, your registration has been submitted '\
+                           'and an email has been sent with payment details.')
+
+    else:
+        registration_form = RegistrationSubmitForm()
+        registrant_form = RegistrantForm()
+        wifi_form = WifiForm()
+
+    login_form = AuthenticationForm()
+
+
+    return render_to_response(template_name, RequestContext(request, {
+        'registration_form': registration_form,
+        'registrant_form' : registrant_form,
+        'over_reg' : reg_count >= REG_TOTAL and True or False,
+        'wifi_form' : wifi_form,
+        'message' : message,
+        'login_form' : login_form
+    }))
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/sponsor/admin.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,15 @@
+# -*- coding: utf-8 -*-
+from __future__ import absolute_import
+
+#django
+from django.contrib import admin
+
+#kiwipycon
+from .models import Sponsor
+
+class SponsorAdmin(admin.ModelAdmin):
+    list_display = ('title', 'type', 'contact_name', 'contact_email', 'contact_phone',
+            'guests', 'url', 'logo')
+
+admin.site.register(Sponsor, SponsorAdmin)
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/sponsor/migrations/0001_initial.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,50 @@
+# -*- coding: utf-8 -*-
+
+from south.db import db
+from django.db import models
+from project.kiwipycon.sponsor.models import *
+
+class Migration:
+    
+    def forwards(self, orm):
+        
+        # Adding model 'Sponsor'
+        db.create_table('sponsor_sponsor', (
+            ('id', models.AutoField(primary_key=True)),
+            ('slug', models.SlugField()),
+            ('title', models.CharField(max_length=255)),
+            ('type', models.CharField(max_length=10)),
+            ('url', models.URLField(verify_exists=False, blank=True)),
+            ('contact_name', models.CharField(max_length=255)),
+            ('contact_phone', models.CharField(max_length=255)),
+            ('contact_email', models.CharField(max_length=255)),
+            ('logo', models.CharField(max_length=64, blank=True)),
+            ('guests', models.IntegerField()),
+        ))
+        db.send_create_signal('sponsor', ['Sponsor'])
+        
+    
+    
+    def backwards(self, orm):
+        
+        # Deleting model 'Sponsor'
+        db.delete_table('sponsor_sponsor')
+        
+    
+    
+    models = {
+        'sponsor.sponsor': {
+            'contact_email': ('models.CharField', [], {'max_length': '255'}),
+            'contact_name': ('models.CharField', [], {'max_length': '255'}),
+            'contact_phone': ('models.CharField', [], {'max_length': '255'}),
+            'guests': ('models.IntegerField', [], {}),
+            'id': ('models.AutoField', [], {'primary_key': 'True'}),
+            'logo': ('models.CharField', [], {'max_length': '64', 'blank': 'True'}),
+            'slug': ('models.SlugField', [], {}),
+            'title': ('models.CharField', [], {'max_length': '255'}),
+            'type': ('models.CharField', [], {'max_length': '10'}),
+            'url': ('models.URLField', [], {'verify_exists': 'False', 'blank': 'True'})
+        }
+    }
+    
+    complete_apps = ['sponsor']
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/sponsor/models.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,28 @@
+# -*- coding: utf-8 -*-
+from __future__ import absolute_import
+
+#django
+from django.db import models
+from django.conf import settings
+
+TYPE_CHOICES = (
+    ('gold', 'Gold'),
+    ('silver', 'Silver'),
+    ('schwag', 'Schwag'),
+    )
+
+class Sponsor(models.Model):
+    """Defines sponsors for *PyCon"""
+    slug = models.SlugField()
+    title = models.CharField(max_length=255)
+    type = models.CharField(max_length=10, choices=TYPE_CHOICES)
+    contact_name = models.CharField(max_length=255)
+    contact_email = models.CharField(max_length=255)
+    contact_phone = models.CharField(max_length=255)
+    url = models.URLField(blank=True, verify_exists=False)
+    logo = models.CharField(max_length=64, blank=True)
+    guests = models.IntegerField()
+
+    def __unicode__(self):
+        return self.title
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/sponsor/views.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,17 @@
+# -*- coding: utf-8 -*-
+from __future__ import absolute_import
+
+# django
+from django.conf import settings
+from django.shortcuts import render_to_response
+from django.template import RequestContext
+
+def schwag_sponsors(request,
+        template_name = 'sponsor/schwag.html'):
+    """Simple page to display schwag sponsors
+    
+    The list is generated in kiwipycon.context_processors
+    """
+    return render_to_response(template_name, RequestContext(request,
+        {}))
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/talk/admin.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,23 @@
+# -*- coding: utf-8 -*-
+from __future__ import absolute_import
+
+#django.contrib
+from django.contrib import admin
+
+#kiwipycon
+from .models import Talk
+
+class TalkAdmin(admin.ModelAdmin):
+    list_display = ('title', 'speaker', 'topic', 'duration', 'audience', 'approved')
+    list_filter = ('approved', 'audience', 'topic', 'speaker')
+    search_fields = ('slug', 'title', 'abstract')
+    prepopulate_from = {'slug': ('title',)}
+    fieldsets = (
+        ('Details', {
+            'fields': ('slug', 'title', 'abstract', 'speaker')
+        }),
+        ('Information', {
+            'fields': ('topic', 'duration', 'audience', 'approved')
+        }),
+    )
+admin.site.register(Talk, TalkAdmin)
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/talk/forms.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,62 @@
+# -*- coding: utf-8 -*-
+from __future__ import absolute_import
+
+#django
+from django import forms
+
+#django.contrib
+from django.contrib.auth.models import User
+
+#tagging
+from tagging.forms import TagField
+
+#kiwipycon
+#from .models import TOPIC_CHOICES
+from .models import DURATION_CHOICES
+from .models import AUDIENCE_CHOICES
+
+
+class TalkSubmitForm(forms.Form):
+    """Submit talk form
+    """
+    authors_bio = forms.CharField(widget=forms.Textarea, required=True,
+        label=u'Author(s) and short bio',
+        help_text=u'(include a bit about your qualifications regarding your presentation topic)')
+    contact = forms.EmailField(required=True, label=u'E-Mail ID',
+        help_text=u'Provide your email ID',
+        max_length=1024,
+        widget=forms.TextInput(attrs={'size':'50'}))
+    title = forms.CharField(required=True, label=u'Talk title',
+        help_text=u'Title of proposed presentation',
+        max_length=1024,
+        widget=forms.TextInput(attrs={'size':'50'}))
+    abstract = forms.CharField(widget=forms.Textarea, required=True,
+        help_text=u'Summary of proposed presentation (around 30 words)')
+#    outline = forms.CharField(widget=forms.Textarea, required=True,
+#        help_text=u'Outline of proposed presentation (around 200 words)')
+#    topic = forms.ChoiceField(choices=TOPIC_CHOICES,
+#        label=u'Topic', help_text=u'Select one of the available options or enter other topic')
+#    topic_other = forms.CharField(label=u'Other topic',
+#        help_text=u'Description of your topic',
+#        max_length=255,
+#        required=False,
+#        widget=forms.TextInput(attrs={'size':'50'}))
+    topic = forms.CharField(label=u'Topic',
+        help_text=u'Description of your topic or comma separated tags',
+        max_length=255,
+        required=False,
+        widget=forms.TextInput(attrs={'size':'50'}))
+    duration = forms.ChoiceField(choices=DURATION_CHOICES, required=True,
+        label=u'Preferred timeslot', help_text=u'Select preferred time slot')
+    audience = forms.ChoiceField(choices=AUDIENCE_CHOICES, label=u'Itended audience',
+        help_text=u'Select one of the available options or enter other type of intended audience')
+#    audience_other = forms.CharField(label=u'Other intended audience',
+#        help_text=u'Description of intended audience (ie. Discordians)',
+#        max_length=128,
+#        required=False,
+#        widget=forms.TextInput(attrs={'size':'50'}))
+#    tags = TagField(max_length=255,
+#        widget=forms.TextInput(attrs={'size':'50'}))
+
+class TalkEditForm(TalkSubmitForm):
+    id = forms.CharField(widget=forms.HiddenInput)
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/talk/migrations/0001_initial.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,68 @@
+# -*- coding: utf-8 -*-
+
+from south.db import db
+from django.db import models
+from project.kiwipycon.talk.models import *
+
+class Migration:
+    
+    def forwards(self, orm):
+        
+        # Adding model 'Talk'
+        db.create_table('talk_talk', (
+            ('id', models.AutoField(primary_key=True)),
+            ('slug', models.SlugField()),
+            ('speaker', models.ForeignKey(orm['auth.User'])),
+            ('authors_bio', models.TextField()),
+            ('contact', models.CharField(max_length=1024)),
+            ('title', models.CharField(max_length=1024)),
+            ('abstract', models.TextField()),
+            ('outline', models.TextField()),
+            ('topic', models.CharField(blank=True, max_length=255)),
+            ('topic_other', models.CharField(max_length=255, blank=True)),
+            ('duration', models.CharField(max_length=3)),
+            ('audience', models.CharField(blank=True, max_length=32)),
+            ('audience_other', models.CharField(max_length=128, blank=True)),
+            ('approved', models.BooleanField(default=False)),
+            ('submitted', models.DateTimeField(auto_now_add=True)),
+            ('last_mod', models.DateTimeField(auto_now=True)),
+            ('tags', TagField(blank=True)),
+        ))
+        db.send_create_signal('talk', ['Talk'])
+        
+    
+    
+    def backwards(self, orm):
+        
+        # Deleting model 'Talk'
+        db.delete_table('talk_talk')
+        
+    
+    
+    models = {
+        'auth.user': {
+            '_stub': True,
+            'id': ('models.AutoField', [], {'primary_key': 'True'})
+        },
+        'talk.talk': {
+            'abstract': ('models.TextField', [], {}),
+            'approved': ('models.BooleanField', [], {'default': 'False'}),
+            'audience': ('models.CharField', [], {'blank': 'True', 'max_length': '32'}),
+            'audience_other': ('models.CharField', [], {'max_length': '128', 'blank': 'True'}),
+            'authors_bio': ('models.TextField', [], {}),
+            'contact': ('models.CharField', [], {'max_length': '1024'}),
+            'duration': ('models.CharField', [], {'max_length': '3'}),
+            'id': ('models.AutoField', [], {'primary_key': 'True'}),
+            'last_mod': ('models.DateTimeField', [], {'auto_now': 'True'}),
+            'outline': ('models.TextField', [], {}),
+            'slug': ('models.SlugField', [], {}),
+            'speaker': ('models.ForeignKey', ['User'], {}),
+            'submitted': ('models.DateTimeField', [], {'auto_now_add': 'True'}),
+            'tags': ('TagField', [], {'blank': 'True'}),
+            'title': ('models.CharField', [], {'max_length': '1024'}),
+            'topic': ('models.CharField', [], {'blank': 'True', 'max_length': '255'}),
+            'topic_other': ('models.CharField', [], {'max_length': '255', 'blank': 'True'})
+        }
+    }
+    
+    complete_apps = ['talk']
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/talk/models.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,73 @@
+# -*- coding: utf-8 -*-
+from __future__ import absolute_import
+
+#django
+from django.db import models
+from django.contrib.auth.models import User
+
+#tagging
+from tagging import register
+from tagging.fields import TagField
+from tagging.utils import parse_tag_input
+
+DURATION_CHOICES = (
+    ('10', 'Lightning Talk (10 mins)'),
+    ('20', 'Short Talk (20 mins)'),
+    ('30', 'Standard Talk (30 mins)'),
+    )
+
+AUDIENCE_CHOICES = (
+    ('nonprogrammers', 'non-programmer'),
+    ('beginers', 'beginning programmer'),
+    ('intermediate', 'intermediate programmer'),
+    ('advanced', 'advanced programmer'),
+    )
+
+#TOPIC_CHOICES = (
+#    ('Core Python', 'Core Python'),
+#    ('Other implementations: Jython, IronPython, PyPy, and Stackless', 'Other implementations: Jython, IronPython, PyPy, and Stackless'),
+#    ('Python libraries and extensions', 'Python libraries and extensions'),
+#    ('Python 3k', 'Python 3k'),
+#    ('Databases', 'Databases'),
+#    ('Documentation', 'Documentation'),
+#    ('GUI Programming', 'GUI Programming'),
+#    ('Game Programming', 'Game Programming'),
+#    ('Network Programming', 'Network Programming'),
+#    ('Open Source Python projects', 'Open Source Python projects'),
+#    ('Packaging Issues', 'Packaging Issues'),
+#    ('Programming Tools', 'Programming Tools'),
+#    ('Project Best Practices', 'Project Best Practices'),
+#    ('Embedding and Extending', 'Embedding and Extending'),
+#    ('Science and Maths', 'Science and Maths'),
+#    ('Web-based Systems', 'Web-based Systems'),
+#)
+
+class Talk(models.Model):
+    """Defines talks at *PyCon"""
+    slug = models.SlugField()
+    speaker = models.ForeignKey(User)
+    authors_bio = models.TextField()
+    contact = models.EmailField()
+    title = models.CharField(max_length=1024)
+    abstract = models.TextField()
+#    outline = models.TextField()
+    topic = models.CharField(max_length=255, 
+                             #choices=TOPIC_CHOICES,
+                             blank=True)
+    #topic_other = models.CharField(max_length=255, blank=True)
+    duration = models.CharField(max_length=3, choices=DURATION_CHOICES)
+    audience = models.CharField(max_length=32, choices=AUDIENCE_CHOICES, blank=True)
+#    audience_other = models.CharField(max_length=128, blank=True)
+    approved = models.BooleanField(default=False)
+    submitted = models.DateTimeField(auto_now_add=True)
+    last_mod = models.DateTimeField(auto_now=True)
+#    tags = TagField(blank=True)
+
+    def __unicode__(self):
+        return self.title
+
+    def get_tag_list(self):
+        return parse_tag_input(self.tags)
+
+# register(Talk) # saving talk failed - see:
+# http://code.google.com/p/django-tagging/issues/detail?id=152
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/talk/templatetags/__init__.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,1 @@
+#
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/talk/templatetags/talk_extras.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,8 @@
+from django import template
+
+register = template.Library()
+
+def choice(choices, value):
+    return choices[value]
+
+register.filter('choice', choice)
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/talk/views.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,183 @@
+# -*- coding: utf-8 -*-
+from __future__ import absolute_import
+
+# python imports
+from urlparse import urlparse
+
+# django
+from django.conf import settings
+from django.shortcuts import render_to_response
+from django.template import RequestContext
+from django.core.urlresolvers import reverse
+from django.views.generic.list_detail import object_list
+from django.views.generic.list_detail import object_detail
+
+from django.contrib.auth.decorators import login_required
+from django.contrib.auth.forms import AuthenticationForm
+from django.contrib.auth.models import User
+
+# PIL
+from PIL import Image
+
+# tagging
+from tagging.models import Tag
+
+#kiwipycon
+from project.kiwipycon.utils import set_message_cookie
+from project.kiwipycon.utils import slugify
+from project.kiwipycon.user.models import UserProfile
+from project.kiwipycon.user.forms import RegisterForm
+from project.kiwipycon.user.utils import kiwipycon_createuser
+
+from .models import Talk
+from .forms import TalkSubmitForm
+from .forms import TalkEditForm
+from .models import DURATION_CHOICES
+from .models import AUDIENCE_CHOICES
+
+def list_talks(request):
+    objects = Talk.objects.filter(approved=True)
+    extra_context = dict(count=objects.count())
+    return object_list(request, objects, extra_context=extra_context)
+
+def talk(request, id):
+    objects = Talk.objects.filter(approved=True)
+    audience = {}
+    for choice in AUDIENCE_CHOICES:
+        audience[choice[0]] = choice[1]
+    extra_context = dict(choices=audience)
+    return object_detail(request, objects, id, extra_context=extra_context)
+
+@login_required
+def edit_talk(request, id, template_name='talk/edit-talk.html'):
+    '''Allows users that submitted a talk to edit it until the talk is approved.
+    '''
+    talk = Talk.objects.get(pk=id)
+
+    if talk.approved == True:
+        redirect_to = reverse('kiwipycon_account')
+        return set_message_cookie(redirect_to,
+                msg = u'Sorry but you cannot edit the talk once'\
+                      + ' it has been accepted.')
+    if talk.speaker != request.user:
+        redirect_to = reverse('kiwipycon_account')
+        return set_message_cookie(redirect_to,
+                msg = u'Redirected to account because the talk you selected' \
+                      + ' is not your own.')
+
+    if request.method == 'POST':
+        form = TalkEditForm(data=request.POST)
+        if form.is_valid():
+            talk.slug = slugify(form.data.get('title'))
+            talk.authors_bio = form.data.get('authors_bio')
+            talk.contact = form.data.get('contact')
+            talk.title = form.data.get('title')
+            talk.abstract = form.data.get('abstract')
+            talk.outline = form.data.get('outline')
+            talk.topic = form.data.get('topic')
+            talk.topic_other = form.data.get('topic_other')
+            talk.duration = form.data.get('duration')
+            talk.audience = form.data.get('audience')
+            talk.audience_other = form.data.get('audience_other')
+            talk.tags = form.data.get('tags')
+            talk.save()
+            # Saved.. redirect
+            redirect_to = reverse('kiwipycon_account')
+            return set_message_cookie(redirect_to,
+                    msg = u'Your changes have been saved.')
+    else:
+        form = TalkEditForm(initial={
+                                    'id' : id,
+                                    'authors_bio' : talk.authors_bio,
+                                    'contact' : talk.contact,
+                                    'title' : talk.title,
+                                    'abstract' : talk.abstract,
+                                    'outline' : talk.outline,
+                                    'topic' : talk.topic,
+                                    'topic_other' : talk.topic_other,
+                                    'duration' : talk.duration,
+                                    'audience' : talk.audience,
+                                    'audience_other' : talk.audience_other,
+                                    'tags' : talk.tags,
+            })
+
+    return render_to_response(template_name, RequestContext(request, locals()))
+
+@login_required()
+def submit_talk(request, template_name='talk/submit-talk.html'):
+    '''Allows user to edit profile
+    '''
+    user = request.user
+    if user.is_authenticated():
+        try:
+            profile = user.get_profile()
+        except:
+            profile, new = UserProfile.objects.get_or_create(user=user)
+            if new:
+                profile.save()
+    message = None
+
+    if request.method == 'POST':
+        talk_form = TalkSubmitForm(data=request.POST)
+
+        register_form = RegisterForm(data=request.POST,
+                                        files=request.FILES)
+
+        if request.POST.get('action', None) == 'login':
+            login_form = AuthenticationForm(data=request.POST)
+            if login_form.is_valid():
+
+                from django.contrib.auth import login
+                login(request, login_form.get_user())
+
+                redirect_to = reverse('kiwipycon_submit_talk')
+                return set_message_cookie(redirect_to,
+                        msg = u'You have been logged in.')
+
+        if request.POST.get('action', None) == 'register':
+            # add the new user
+            if register_form.is_valid():
+
+                user = kiwipycon_createuser(request, register_form.data)
+
+        if talk_form.is_valid():
+            if user.is_authenticated():
+                title = talk_form.data.get('title')
+                talk = Talk.objects.create(
+                    slug = slugify(title),
+                    speaker = User.objects.get(pk=user.id),
+                    authors_bio = talk_form.data.get('authors_bio'),
+                    contact = talk_form.data.get('contact'),
+                    title = talk_form.data.get('title'),
+                    abstract = talk_form.data.get('abstract'),
+                    outline = talk_form.data.get('outline'),
+                    topic = talk_form.data.get('topic'),
+                    topic_other = talk_form.data.get('topic_other'),
+                    duration = talk_form.data.get('duration'),
+                    audience = talk_form.data.get('audience'),
+                    audience_other = talk_form.data.get('audience_other'),
+                    approved = False,
+                    tags = talk_form.data.get('tags'))
+                talk.save()
+                # Saved, ... redirect back to account
+                redirect_to = reverse('kiwipycon_account')
+                return set_message_cookie(redirect_to,
+                        msg = u'Thanks, your talk has been submitted.')
+            else:
+                redirect_to = reverse('kiwipycon_submit_talk')
+                return set_message_cookie(redirect_to,
+                        msg = u'Something is wrong here.')
+
+    else:
+        talk_form = TalkSubmitForm()
+        register_form = RegisterForm()
+    login_form = AuthenticationForm()
+
+
+    return render_to_response(template_name, RequestContext(request, {
+        'talk_form': talk_form,
+        'register_form' : register_form,
+        'message' : message,
+        'login_form' : login_form
+    }))
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/user/admin.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,17 @@
+# -*- coding: utf-8 -*-
+from __future__ import absolute_import
+
+#django
+from django.contrib import admin
+
+#kiwipycon
+from .models import UserProfile
+
+class UserProfileAdmin(admin.ModelAdmin):
+    list_display = ('user', 'email',  'url', 'about')
+
+    def email(self, obj):
+        return obj.user.email
+
+admin.site.register(UserProfile, UserProfileAdmin)
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/user/forms.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,135 @@
+# -*- coding: utf-8 -*-
+from __future__ import absolute_import
+
+#django
+from django import forms
+from django.contrib.auth.models import User
+
+class RegistrantForm(forms.Form):
+    """Form to register an attendee
+    """
+    username = forms.RegexField(label="Nickname", max_length=30,
+            regex=r'^\w+$',
+        help_text = "30 characters or fewer. Alphanumeric" \
+            + " characters only (letters, digits and underscores).",
+        error_message = "This value must contain only letters, numbers and underscores.")
+    name = forms.CharField(label=u"Name", max_length=50, required=True)
+    email = forms.EmailField(label=u"E-mail", max_length=50, required=True)
+
+    def clean_email(self):
+        """Validates that the entered e-mail is unique.
+        """
+        email = self.cleaned_data.get("email")
+        if email and User.objects.filter(email=email).count() > 0:
+            raise forms.ValidationError(
+                u"That email address is already in use. Are you a member of " \
+                 "site? Please log in.")
+
+        return email
+
+    def clean_username(self):
+        """Validates that the entered username is unique.
+        """
+        username = self.cleaned_data.get("username")
+        if username and User.objects.filter(username=username).count() > 0:
+            raise forms.ValidationError(
+                u"That username is already in use.")
+
+        return username
+
+class RegisterForm(forms.Form):
+    """Form to register speaker
+    """
+    username = forms.RegexField(label="Username", max_length=30,
+            regex=r'^\w+$',
+        help_text = "Required. 30 characters or fewer. Alphanumeric" \
+            + " characters only (letters, digits and underscores).",
+        error_message = "This value must contain only letters, numbers and underscores.")
+    first_name = forms.CharField(label=u"First name", max_length=50)
+    last_name = forms.CharField(label=u"Last name", max_length=50)
+    email = forms.EmailField(label=u"E-mail", max_length=50)
+    url = forms.URLField(required=False)
+    about = forms.CharField(label=u'Short Bio', max_length=50, required=False)
+    photo = forms.FileField(label=u'Profile Photo', required=False)
+    password_1 = forms.CharField(
+        label=u"Password", widget=forms.PasswordInput(), max_length=20)
+    password_2 = forms.CharField(
+        label=u"Confirm password", widget=forms.PasswordInput(), max_length=20)
+
+    def clean_password_2(self):
+        """Validates that password 1 and password 2 are the same.
+        """
+        p1 = self.cleaned_data.get('password_1')
+        p2 = self.cleaned_data.get('password_2')
+
+        if not (p1 and p2 and p1 == p2):
+            raise forms.ValidationError(u"The two passwords do not match.")
+
+        return p2
+
+    def clean_email(self):
+        """Validates that the entered e-mail is unique.
+        """
+        email = self.cleaned_data.get("email")
+        if email and User.objects.filter(email=email).count() > 0:
+            raise forms.ValidationError(
+                u"That email address is already in use.")
+
+        return email
+
+    def clean_username(self):
+        """Validates that the entered username is unique.
+        """
+        username = self.cleaned_data.get("username")
+        if username and User.objects.filter(username=username).count() > 0:
+            raise forms.ValidationError(
+                u"That username is already in use.")
+
+        return username
+
+class EditProfileForm(forms.Form):
+    """Edit user profile form
+    """
+    first_name = forms.CharField(max_length=50)
+    last_name = forms.CharField(max_length=50)
+    email = forms.EmailField(max_length=50)
+    email2 = forms.CharField(widget=forms.HiddenInput)
+    url = forms.URLField(required=False)
+    about = forms.CharField(label=u'Short Bio',
+            widget=forms.Textarea, required=False)
+    photo = forms.FileField(label=u'Profile Photo',
+            required=False)
+
+    def clean_email(self):
+        """Validates that the entered e-mail is unique.
+        """
+        email = self.cleaned_data.get("email")
+        email2 = self.data.get("email2").strip()
+        print email, email2
+        if email != email2: # email has been changed
+            if email and User.objects.filter(email=email).count() > 0:
+                raise forms.ValidationError(
+                    u"That email address is already in use.")
+
+        return email
+
+class UsernameForm(forms.Form):
+    """Form to edit email address
+    """
+    username = forms.RegexField(label="Username", max_length=30,
+            regex=r'^\w+$',
+        help_text = "Required. 30 characters or fewer. Alphanumeric" \
+            + " characters only (letters, digits and underscores).",
+        error_message = "This value must contain only letters, numbers and underscores.")
+
+    def clean_username(self):
+        """Validates that the entered username is unique.
+        """
+        username = self.cleaned_data.get("username")
+        if username and User.objects.filter(username=username).count() > 0:
+            raise forms.ValidationError(
+                u"That username is already in use.")
+
+        return username
+
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/user/migrations/0001_initial.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,44 @@
+# -*- coding: utf-8 -*-
+
+from south.db import db
+from django.db import models
+from project.kiwipycon.user.models import *
+
+class Migration:
+    
+    def forwards(self, orm):
+        
+        # Adding model 'UserProfile'
+        db.create_table('user_userprofile', (
+            ('id', models.AutoField(primary_key=True)),
+            ('user', models.ForeignKey(orm['auth.User'], unique=True)),
+            ('url', models.URLField(verify_exists=False, blank=True)),
+            ('photo', models.CharField(max_length=64, blank=True)),
+            ('about', models.TextField(blank=True)),
+        ))
+        db.send_create_signal('user', ['UserProfile'])
+        
+    
+    
+    def backwards(self, orm):
+        
+        # Deleting model 'UserProfile'
+        db.delete_table('user_userprofile')
+        
+    
+    
+    models = {
+        'auth.user': {
+            '_stub': True,
+            'id': ('models.AutoField', [], {'primary_key': 'True'})
+        },
+        'user.userprofile': {
+            'about': ('models.TextField', [], {'blank': 'True'}),
+            'id': ('models.AutoField', [], {'primary_key': 'True'}),
+            'photo': ('models.CharField', [], {'max_length': '64', 'blank': 'True'}),
+            'url': ('models.URLField', [], {'verify_exists': 'False', 'blank': 'True'}),
+            'user': ('models.ForeignKey', ['User'], {'unique': 'True'})
+        }
+    }
+    
+    complete_apps = ['user']
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/user/models.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,36 @@
+# -*- coding: utf-8 -*-
+from __future__ import absolute_import
+
+#django
+from django.db import models
+from django.conf import settings
+from django.db.models.signals import post_save
+from django.contrib.auth.models import User
+
+class UserProfile(models.Model):
+    """
+    Extend atributes for django User
+    """
+    user = models.ForeignKey(User, unique=True)
+    url = models.URLField(blank=True, verify_exists=False)
+    photo = models.CharField(max_length=64, blank=True)
+    about = models.TextField(blank=True)
+
+    def __unicode__(self):
+        return 'UserProfile for user: <%s %s> %s' % (self.user.first_name,
+                self.user.last_name, self.user.email)
+
+    def fullname(self):
+        return '%s %s' % (self.user.first_name, self.user.last_name)
+
+def add_profile(sender, instance, signal, *args, **kwargs):
+    """Create user profile on create of new user"""
+    if not instance.is_superuser:
+        try:
+            profile, new = UserProfile.objects.get_or_create(user=instance)
+            if new:
+                profile.save()
+        except:
+            pass
+
+post_save.connect(add_profile, sender=User, weak=False)
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/user/utils.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,122 @@
+# -*- coding: utf-8 -*-
+from __future__ import absolute_import
+
+#python imports
+import os
+
+#django
+from django.conf import settings
+from django.core.exceptions import ObjectDoesNotExist
+
+#django.contrib
+from django.contrib.auth.models import User
+
+#PIL
+from PIL import Image
+
+
+def kiwipycon_createregistrant(request, data):
+    """Create user"""
+    email = data.get("email")
+    name = data.get("name")
+    username = data.get("username")
+
+    n = name.split(" ")
+    if len(n) > 1:
+        first_name = ' '.join(n[:-1])
+        last_name = n[-1]
+    else:
+        first_name = ''
+        last_name = n[0]
+
+
+    # Create user
+    user = User.objects.create_user(username=username, email=email)
+    user.first_name = first_name
+    user.last_name = last_name
+    user.save()
+
+    return user
+
+def kiwipycon_createuser(request, data):
+    """Create user"""
+    email = data.get("email")
+    username = data.get("username")
+    password = data.get("password_1")
+    password = data.get("password_1")
+
+    # Create user
+    user = User.objects.create_user(
+        username=username, email=email, password=password)
+    user.first_name = data.get("first_name")
+    user.last_name = data.get("last_name")
+    user.save()
+
+    # Log in user
+    from django.contrib.auth import authenticate
+    user = authenticate(username=username, password=password)
+
+    from django.contrib.auth import login
+    login(request, user)
+
+    profile = user.get_profile()
+    photo = request.FILES.get('photo', None)
+    filename= None
+    if photo:
+        filename = handle_uploaded_photo(user, request.FILES['photo'])
+    if filename:
+        profile.photo = filename
+    print photo, filename
+
+    profile.url = data.get("url")
+    profile.about = data.get("about")
+    profile.save()
+
+    return user
+
+def handle_uploaded_photo(user, ufile):
+    usermedia = settings.USER_MEDIA_ROOT
+    filename = ufile.name
+    ext = filename.split('.')[-1]
+    filesize = ufile.size
+    filecontent = ufile.read()
+    userfilename = 'user-%d.%s' % (user.id, ext)
+    if not filecontent:
+        return None
+
+    #save
+    foutname = os.path.join(usermedia, userfilename)
+
+    fout = file(foutname, 'wb')
+    fout.write(filecontent)
+    fout.close()
+
+    # crop and resize
+    image = Image.open(foutname)
+    pw = image.size[0]
+    ph = image.size[1]
+    nw = nh = 80
+    if (pw, ph) != (nw, nh):
+        pr = float(pw) / float(ph)
+        nr = float(nw) / float(nh)
+
+        if pr > nr:
+            # photo aspect is wider than destination ratio
+            tw = int(round(nh * pr))
+            image = image.resize((tw, nh), Image.ANTIALIAS)
+            l = int(round(( tw - nw ) / 2.0))
+            image = image.crop((l, 0, l + nw, nh))
+        elif pr < nr:
+            # photo aspect is taller than destination ratio
+            th = int(round(nw / pr))
+            image = image.resize((nw, th), Image.ANTIALIAS)
+            t = int(round(( th - nh ) / 2.0))
+            print((0, t, nw, t + nh))
+            image = image.crop((0, t, nw, t + nh))
+        else:
+            # photo aspect matches the destination ratio
+            image = image.resize((nw, nh), Image.ANTIALIAS)
+
+        image.save(str(foutname))
+    return userfilename
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/user/views.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,238 @@
+# -*- coding: utf-8 -*-
+from __future__ import absolute_import
+#python
+from urlparse import urlparse
+import urllib
+import os
+
+#django
+from django.conf import settings
+from django.shortcuts import render_to_response
+from django.template import RequestContext
+from django.core.urlresolvers import reverse
+from django.db.models.signals import post_save
+
+#django.contrib
+from django.contrib.auth.decorators import login_required
+from django.contrib.auth.forms import AuthenticationForm
+from django.contrib.auth.forms import PasswordChangeForm
+from django.core.exceptions import ObjectDoesNotExist
+
+#PIL
+from PIL import Image
+
+#kiwipycon
+from project.kiwipycon.utils import set_message_cookie
+from project.kiwipycon.talk.models import Talk
+from project.kiwipycon.registration.models import Registration
+from project.kiwipycon.registration.models import Wifi
+from project.kiwipycon.registration.forms import WifiForm
+from project.kiwipycon.sponsor.models import Sponsor
+
+from .utils import kiwipycon_createuser
+from .utils import handle_uploaded_photo
+from .forms import RegisterForm
+from .forms import EditProfileForm
+from .forms import UsernameForm
+
+@login_required
+def account(request, template_name="user/account.html"):
+    """Displays the main screen of the current user's account.
+    """
+    user = request.user
+    profile = user.get_profile()
+
+    talks = Talk.objects.filter(speaker=user)
+    try:
+        registration = Registration.objects.get(registrant=user)
+    except ObjectDoesNotExist:
+        registration = None
+    try:
+        wifiobj = Wifi.objects.get(user=user)
+    except ObjectDoesNotExist:
+        wifiobj = None
+
+    if profile.photo:
+        photo = os.path.join(settings.USER_MEDIA_URL, profile.photo)
+    else:
+        photo = '/img/user-default.png'
+
+    qstring = ""
+
+    wifi_comment = None
+    if wifiobj:
+        wifi_form = False
+    else:
+        if request.method == "POST":
+            wifi_form = WifiForm(request.POST)
+            if wifi_form.is_valid():
+                wifi_form.save(user)
+            wifi_comment = 'Thanks, your wifi preference has been saved'
+            wifi_form = None
+        else:
+            wifi_form = WifiForm()
+
+    return render_to_response(template_name, RequestContext(request, {
+        "form" : wifi_form, "comment": wifi_comment,
+        "user" : user, "profile" : profile, "photo" : photo,
+        "talks" : talks, "registration" : registration,
+    }))
+
+@login_required
+def edit_profile(request, template_name="user/editprofile.html"):
+    """Allows user to edit profile
+    """
+    user = request.user
+    profile = user.get_profile()
+
+    if request.method == "POST":
+        form = EditProfileForm(data=request.POST,
+                               files=request.FILES)
+
+        if form.is_valid():
+            photo = request.FILES.get('photo', None)
+            filename= None
+            if photo:
+                filename = handle_uploaded_photo(user, request.FILES['photo'])
+            if filename:
+                profile.photo = filename
+
+            user.email = form.data.get("email")
+            user.first_name = form.data.get("first_name")
+            user.last_name = form.data.get("last_name")
+            user.save()
+
+            profile.url = form.data.get("url")
+            profile.about = form.data.get("about")
+            profile.save()
+
+            redirect_to = reverse("kiwipycon_account")
+            return set_message_cookie(redirect_to,
+                    msg = u"Your profile has been changed.")
+
+    else:
+        form = EditProfileForm(initial={"email" : user.email,
+                                        "email2" : user.email, # hidden field
+                                        "first_name" : user.first_name,
+                                        "last_name" : user.last_name,
+                                        "url" : profile.url,
+                                        "about" : profile.about,
+                                        })
+
+    return render_to_response(template_name, RequestContext(request, {
+        "form": form
+    }))
+
+def login(request, template_name="user/login.html"):
+    """Custom view to login or register/login a user.
+    Integration of register and login form
+    It uses Django's standard AuthenticationForm, though.
+    """
+    user = request.user
+    if user.is_authenticated():
+        redirect_to = reverse("kiwipycon_account")
+        return set_message_cookie(redirect_to,
+                msg = u"Redirected to account from login form.")
+
+    # Using Djangos default AuthenticationForm
+    login_form = AuthenticationForm()
+    register_form = RegisterForm()
+
+    if request.POST.get("action") == "login":
+        login_form = AuthenticationForm(data=request.POST)
+
+        if login_form.is_valid():
+            redirect_to = request.POST.get("next")
+            # Light security check -- make sure redirect_to isn't garbage.
+            if not redirect_to or '//' in redirect_to or ' ' in redirect_to:
+                redirect_to = reverse("kiwipycon_account")
+
+            from django.contrib.auth import login
+            login(request, login_form.get_user())
+
+            return set_message_cookie(redirect_to, msg = u"You have been logged in.")
+
+    elif request.POST.get("action") == "register":
+        register_form = RegisterForm(data=request.POST)
+        if register_form.is_valid():
+
+            user = kiwipycon_createuser(request, register_form.data)
+
+            redirect_to = request.POST.get("next")
+            if not redirect_to or '//' in redirect_to or ' ' in redirect_to:
+                redirect_to = reverse("kiwipycon_account")
+
+            return set_message_cookie(
+                redirect_to, msg = u"You have been registered and logged in.")
+
+    # Get next_url
+    next_url = request.REQUEST.get("next")
+    if next_url is None:
+        next_url = request.META.get("HTTP_REFERER")
+    if next_url is None:
+        next_url = reverse("kiwipycon_account")
+    # Get just the path of the url. See django.contrib.auth.views.login for more
+    next_url = urlparse(next_url)
+    next_url = next_url[2]
+
+    try:
+        login_form_errors = login_form.errors["__all__"]
+    except KeyError:
+        login_form_errors = None
+
+    return render_to_response(template_name, RequestContext(request, {
+        "login_form" : login_form,
+        "login_form_errors" : login_form_errors,
+        "register_form" : register_form,
+        "next_url" : next_url,
+    }))
+
+def logout(request):
+    """Custom method to logout a user.
+
+    The reason to use a custom logout method is just to provide a login and a
+    logoutmethod on one place.
+    """
+    from django.contrib.auth import logout
+    logout(request)
+
+    redirect_to = '/'
+    return set_message_cookie(redirect_to, msg = u"You have been logged out.")
+
+@login_required
+def password(request, template_name="user/password.html"):
+    """Changes the password of current user.
+    """
+    if request.method == "POST":
+        form = PasswordChangeForm(request.user, request.POST)
+        if form.is_valid():
+            form.save()
+            redirect_to = reverse("kiwipycon_account")
+            return set_message_cookie(redirect_to,
+                    msg = u"Your password has been changed.")
+    else:
+        form = PasswordChangeForm(request.user)
+
+    return render_to_response(template_name, RequestContext(request, {
+        "form" : form
+    }))
+
+@login_required
+def username(request, template_name="user/username.html"):
+    """Saves the username from the data form.
+    """
+    if request.method == "POST":
+        username_form = UsernameForm(initial={"username" : request.user.username}, data=request.POST)
+        if username_form.is_valid():
+            request.user.username = username_form.cleaned_data.get("username")
+            request.user.save()
+            redirect_to = reverse("kiwipycon_account")
+            return set_message_cookie(redirect_to,
+                    msg = u"Your username has been changed.")
+    else:        
+        username_form = UsernameForm(initial={"username" : request.user.username})
+
+    return render_to_response(template_name, RequestContext(request, {
+        "form": username_form
+    }))
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/kiwipycon/utils.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,40 @@
+# -*- coding: utf-8 -*-
+#python
+import urllib
+import datetime
+import re
+from random import randint
+
+#django
+from django.http import HttpResponseRedirect
+
+def kiwipycon_quote(string, encoding="utf-8"):
+    """Encodes string to encoding before quoting.
+    """
+    return urllib.quote(string.encode(encoding))
+
+# from LFS
+def set_message_cookie(url, msg):
+    """Creates response object with given url and adds message cookie with passed
+    message.
+    """
+
+    # We just keep the message two seconds.
+    max_age = 2
+    expires = datetime.datetime.strftime(
+        datetime.datetime.utcnow() +
+        datetime.timedelta(seconds=max_age), "%a, %d-%b-%Y %H:%M:%S GMT")
+
+    response = HttpResponseRedirect(url)
+    response.set_cookie("message", kiwipycon_quote(msg), max_age=max_age, expires=expires)
+
+    return response
+
+# from django-snippets
+def slugify(inStr):
+    removelist = ["a", "an", "as", "at", "before", "but", "by", "for","from","is", "in", "into", "like", "of", "off", "on", "onto","per","since", "than", "the", "this", "that", "to", "up", "via","with"];
+    for a in removelist:
+        aslug = re.sub(r'\b'+a+r'\b','',inStr)
+    aslug = re.sub('[^\w\s-]', '', aslug).strip().lower()
+    aslug = re.sub('\s+', '-', aslug)
+    return len(aslug) > 50 and '%s-%d' % (aslug[:43], randint(100000,999999)) or aslug
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/production.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,32 @@
+#django
+from project.settings import *
+
+SITE_ID = 2
+
+INSTALLED_APPS = (
+    'django.contrib.auth',
+    'django.contrib.contenttypes',
+    'django.contrib.comments',
+    'django.contrib.sessions',
+    'django.contrib.admin',
+    'django.contrib.sites',
+    'django.contrib.flatpages',
+    'django.contrib.markup',
+    'project.kiwipycon',
+    'project.kiwipycon.user',
+    'project.kiwipycon.talk',
+    'project.kiwipycon.registration',
+    'project.kiwipycon.sponsor',
+    'tagging',
+    'basic.blog',
+    'basic.inlines',
+    'basic.media',
+    'django_extensions',
+    'south',
+)
+
+DATABASE_ENGINE = 'postgresql_psycopg2'
+DATABASE_NAME = 'kpc09'
+DATABASE_USER = 'kpc09'
+# Imports DATABASE_PASSWORD from project/local.py that is not part of mercurial repo
+from project.local import DATABASE_PASSWORD
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/settings.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,76 @@
+
+import os
+
+ADMINS = (
+    ('Madhusudan.C.S', 'admin@scipy.in'),
+)
+
+MANAGERS = ADMINS
+
+DATABASE_HOST = ''
+DATABASE_PORT = ''
+
+TIME_ZONE = 'Asia/Kolkata'
+
+LANGUAGE_CODE = 'en-us'
+
+# Absolute path to the directory that holds media.
+# Example: "/home/media/media.lawrence.com/"
+MEDIA_ROOT = os.path.join(os.path.dirname(__file__), 'media')
+
+USER_MEDIA_ROOT = os.path.join(os.path.dirname(__file__), 'media', 'user')
+USER_MEDIA_PDF = os.path.join(os.path.dirname(__file__), 'media', 'pdf')
+
+# URL that handles the media served from MEDIA_ROOT. Make sure to use a
+# trailing slash if there is a path component (optional in other cases).
+# Examples: "http://media.lawrence.com", "http://example.com/media/"
+MEDIA_URL = '/media/'
+
+USER_MEDIA_URL = '/media/user/'
+
+# Absolute path to the directory that holds static files.
+# Example: "/home/static-files/static-files.lawrence.com/"
+STATIC_ROOT = os.path.join(os.path.dirname(__file__), 'static')
+
+# URL that handles the static files served from MEDIA_ROOT. Make sure to use a
+# trailing slash if there is a path component (optional in other cases).
+# Examples: "http://static-files.lawrence.com", "http://example.com/static-files/"
+STATIC_URL = '/'
+
+# URL prefix for admin media -- CSS, JavaScript and images. Make sure to use a
+# trailing slash.
+# Examples: "http://foo.com/media/", "/media/".
+ADMIN_MEDIA_PREFIX = '/admin_media/'
+
+# Don't share this with anybody.
+SECRET_KEY = 'o)l1m*xi4%7*2dkbwcou2vc48vo8v48y3obyou3hb3bh$t25zd'
+
+MIDDLEWARE_CLASSES = (
+    'django.middleware.common.CommonMiddleware',
+    'django.contrib.sessions.middleware.SessionMiddleware',
+    'django.contrib.auth.middleware.AuthenticationMiddleware',
+    'django.middleware.doc.XViewMiddleware',
+    'django.contrib.flatpages.middleware.FlatpageFallbackMiddleware',
+)
+
+ROOT_URLCONF = 'project.urls'
+
+TEMPLATE_LOADERS = (
+    'django.template.loaders.filesystem.load_template_source',
+    'django.template.loaders.app_directories.load_template_source',
+)
+
+TEMPLATE_DIRS = (
+    os.path.join(os.path.dirname(__file__), "templates"),
+)
+
+LOGIN_URL = "/login"
+
+AUTH_PROFILE_MODULE = 'user.UserProfile'
+
+TEMPLATE_CONTEXT_PROCESSORS = (
+        'django.core.context_processors.auth',
+        'django.core.context_processors.debug',
+        'django.core.context_processors.i18n',
+        'django.core.context_processors.media',
+        'project.kiwipycon.context_processors.sponsors')
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/setup.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,14 @@
+
+from setuptools import setup
+
+setup(
+    name='project',
+    version='1.0',
+    description="KiwiPyCon django website",
+    entry_points={
+        "console_scripts": [
+            'initdb = scripts.initdb:main',
+        ]
+    },
+)
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/static/admin_media	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,1 @@
+../../parts/django/django/contrib/admin/media/
\ No newline at end of file
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/static/css/styles-20090809.css	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,1 @@
+styles.css
\ No newline at end of file
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/static/css/styles-20090826.css	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,1 @@
+styles.css
\ No newline at end of file
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/static/css/styles.css	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,435 @@
+html,
+body
+{
+    margin: 0;
+    padding: 0;
+    font-family: Verdana, Arial, "Bitstream Vera Sans", Helvetica, sans-serif;
+    font-size: 1em;
+    background-color: white;
+    color: #58585a;
+}
+
+p {
+    text-indent: 1em;
+    width: 70%;
+}
+pre.plain {
+    font-family: Verdana, Arial, "Bitstream Vera Sans", Helvetica, sans-serif;
+    font-size: 1em;
+    color: #58585a;
+    margin-left: 1em;
+}
+img
+{
+    border: 0;
+}
+
+a
+{
+    color: #224466;
+}
+
+h1,
+h2,
+h3,
+h4,
+h5
+{
+    font-family: Georgia, "Bitstream Vera Serif", Palatino, serif;
+    font-weight: normal;
+    line-height: 1em;
+}
+
+h1
+{
+    font-size: 1.8em;
+    color: #224466;
+    margin: 0.5em 0 0.7em 0;
+    text-decoration: none;
+    padding-bottom: 0.5em;
+/*    border-bottom: 1px solid #224466; */
+    width: 80%;
+}
+
+h2
+{
+    font-size: 1.5em;
+    color: #337799;
+    margin: 0.7em 0 0.5em 0;
+}
+
+h3
+{
+    font-size: 1.25em;
+    font-style: italic;
+    color: #337799;
+    margin: 0.5em 0;
+}
+
+ul.plain {
+  list-style: none;
+  list-style-type: none;
+  margin: 0; padding: 0;
+}
+/* give some color to <span class="title">Kiwi PyCon 2009</span> */
+span.title
+{
+}
+div#comment_form {
+    border-top: 1px solid #ccc;
+}
+div#comment_form label {
+    width: 200px;
+}
+/* default table layout */
+table.kiwipycon-default
+{
+    border-collapse: collapse;
+}
+
+table.kiwipycon-default td
+{
+    padding: 5px 15px;
+}
+
+table.kiwipycon-default th
+{
+    font-weight: bold;
+    padding: 4px 6px;
+}
+
+table.kiwipycon-default a
+{
+    text-decoration: none;
+}
+
+table.kiwipycon-default .buttons
+{
+    padding: 10px 0;
+}
+
+tr.odd {
+    background-color: #efefef;
+}
+tr.even {
+    background-color: #fff;
+}
+td,
+th
+{
+    text-align:left;
+    vertical-align: top;
+}
+
+.important
+{
+    color: #337799;
+    font-weight: bold;
+}
+
+.clear
+{
+    clear: both;
+}
+
+/* user account */
+div.picture
+{
+    width: 80%;
+    text-align: right;
+}
+
+div.picture img
+{
+    border: 1px solid #ddd;
+}
+
+/* layout elements */
+#logo
+{
+    border: 0;
+    margin: 0;
+    padding: 0.5em 1.5em;
+    background-color: #f1f1f1;
+    border-bottom: 1px dotted #888888;
+}
+#logo a img {
+    border: 0;
+}
+
+/* layout */
+#header
+{
+    position: absolute;
+    top: 1.55em;
+    left: 400px;
+}
+
+#wrapper
+{
+    position: relative;
+}
+
+#left
+{
+    width: 200px;
+    font-size: 0.8em;
+    float: left;
+}
+
+#content
+{
+    font-size: 0.8em;
+    padding: 0;
+    margin: 0 240px 0 220px;
+    min-height: 850px;
+}
+
+#right
+{
+    position: absolute;
+    top: 0;
+    right: 0;
+    width: 250px;
+    font-size: 0.8em;
+    float: right;
+    margin: 0;
+    padding: 0 2em 0 0;
+}
+
+#right h2
+{
+    margin: 0;
+    padding: 0;
+}
+
+#footer
+{
+    border-top: 1px dotted #888888;
+    margin: 150px 0 0;
+    padding: 0 1em;
+    font-size: 0.5em;
+    clear: both;
+    position: relative;
+}
+
+/* jquery growl appears on right */
+#header h1
+{
+    font-size: 2.75em;
+    color: #224466;
+    font-family: Georgia, "Bitstream Vera Serif", Palatino, serif;
+    border: none !important;
+    width: 100%;
+    margin: 0;
+    padding: 0;
+    padding-bottom: 0.2em;
+}
+
+#header h3
+{
+	  font-size: 1.2em;
+	  font-family: Georgia, "Bitstream Vera Serif", Palatino, serif;
+	  border: none !important;
+	  width: 100%;
+	  margin: 0;
+	  padding: 0;
+	  padding-bottom: 0.2em;
+}
+#menu-user
+{
+    position: absolute;
+    right: 0em;
+    font-size: 0.8em;
+}
+
+#menu-user a
+{
+    text-decoration: none;
+}
+
+#left-inner
+{
+    margin: 0 2em;
+    padding: 0;
+}
+
+#left-inner a {
+    text-decoration: none;
+}
+
+#left-inner ul
+{
+    list-style: none;
+    list-style-type: none;
+    margin: 0;
+    padding: 0;
+    border: 0;
+}
+
+#left-inner ul li ul
+{
+    margin-left: 0.5em;
+    padding: 0;
+}
+
+#left-inner li
+{
+    font-weight: bold;
+    padding: 0 0 0.5em 0;
+}
+
+#left-inner li ul li
+{
+    font-weight: normal;
+    padding: 0 0 0.3em 0;
+}
+
+#right-inner {
+    margin: 0;
+    padding: 0;
+}
+
+#right-inner ul
+{
+    list-style: none;
+    margin: 0;
+    padding: 0;
+    border: 0;
+}
+
+#right-inner li
+{
+	  font-weight: bold;
+    padding-bottom: 15px;
+}
+/* forms */
+div.form
+{
+    margin-top: 1em;
+}
+
+div.form th
+{
+    text-align: left;
+}
+fieldset {
+    width: 70%;
+}
+legend {
+    font-weight: bold;
+    color: #222;
+}
+div.messages {
+    padding:.3em .8em;
+    margin-bottom:1em;
+    border:2px solid #ddd;
+    background:#E3FBE4;
+    color:#1f8a11;
+    border-color:#C2FBC4;
+}
+.notice {
+    background:#FFF6BF;
+    color:#514721;
+    border-color:#FFD324;
+    padding:.8em;
+    margin-bottom:1em;
+    border:2px solid #ddd;
+}
+ul.errorlist, .errors, .error {
+    padding:.3em .8em;
+    margin-bottom:1em;
+    border:2px solid #ddd;
+    background:#FBE3E4;
+    color:#8a1f11;
+    border-color:#FBC2C4;
+}
+ul.errorlist {
+  list-style: none;
+  list-style-type: none;
+}
+/* Login/register */
+div.login
+{
+    float: left;
+}
+
+div.register
+{
+    padding-left: 2em;
+    margin: 0 0 0 270px;
+    border-left: 1px solid #aaa;
+}
+
+/* --------------------------------------------------------------
+   Based on buttons by Kevin Hale [particletree.com]
+   * particletree.com/features/rediscovering-the-button-element
+-------------------------------------------------------------- */
+
+a.button, button, input.button {
+  display:block;
+  float: right;
+  margin: 0.7em 8px 0.7em 0.5em;
+  padding:2px 10px 2px 10px;   /* Links */
+  font-size:100%;
+  line-height:120%;
+  text-decoration:none;
+  font-weight:bold;
+  cursor:pointer;
+  background-color: #66aacc;
+  border: 1px solid #222;
+  color: #fff !important;
+}
+
+a.button.left, button.left, input.left {
+  margin: 0.7em 0.5em 0.7em 0em;
+  float:left;
+}
+
+button {
+  width:auto;
+  overflow:visible;
+  padding:4px 10px 3px 7px;   /* IE6 */
+}
+
+button[type] {
+  padding:4px 10px 4px 7px;   /* Firefox */
+  line-height:17px;           /* Safari */
+}
+
+*:first-child+html button[type] {
+  padding:4px 10px 3px 7px;   /* IE7 */
+}
+
+button img, a.button img {
+  margin:0 3px -3px 0 !important;
+  padding:0;
+  border:none;
+  width:16px;
+  height:16px;
+  float:none;
+}
+
+table.required tr {
+    border-left: 3px solid #cc0000;
+}
+
+/* Button colors */
+
+/* Standard */
+button:hover, a.button:hover, input.button:hover {
+  background-color: #337799;
+  border: 1px solid #222;
+  color:black !important;
+}
+
+/* horizontal menu */
+div.right {
+    text-align: right;
+    width: 80%;
+}
+ul.horizontal-menu li {
+  display: inline;
+  list-style-type: none;
+  padding-right: 20px;
+}
Binary file project/static/doc/Kiwi PyCon Media Statement 2.doc has changed
Binary file project/static/doc/Kiwi PyCon Media Statement.doc has changed
Binary file project/static/img/apress.png has changed
Binary file project/static/img/bliptv.gif has changed
Binary file project/static/img/canonical.png has changed
Binary file project/static/img/catalyst.png has changed
Binary file project/static/img/encode.png has changed
Binary file project/static/img/favicon.ico has changed
Binary file project/static/img/flickr.png has changed
Binary file project/static/img/logo-s.png has changed
Binary file project/static/img/logo.jpg has changed
Binary file project/static/img/logo.png has changed
Binary file project/static/img/oreilly.png has changed
Binary file project/static/img/packt.png has changed
Binary file project/static/img/plone.png has changed
Binary file project/static/img/powerhouse.png has changed
Binary file project/static/img/pretaweb.png has changed
Binary file project/static/img/psf.png has changed
Binary file project/static/img/scipyshiny_small.png has changed
Binary file project/static/img/slideshare.png has changed
Binary file project/static/img/tait.png has changed
Binary file project/static/img/twitter.png has changed
Binary file project/static/img/unfold.png has changed
Binary file project/static/img/user-default.png has changed
Binary file project/static/img/vortex.png has changed
Binary file project/static/img/webstock.png has changed
Binary file project/static/img/weta.jpg has changed
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/static/jquery/jquery.cookie.pack.js	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,10 @@
+/**
+ * Cookie plugin
+ *
+ * Copyright (c) 2006 Klaus Hartl (stilbuero.de)
+ * Dual licensed under the MIT and GPL licenses:
+ * http://www.opensource.org/licenses/mit-license.php
+ * http://www.gnu.org/licenses/gpl.html
+ *
+ */
+eval(function(p,a,c,k,e,r){e=function(c){return(c<a?'':e(parseInt(c/a)))+((c=c%a)>35?String.fromCharCode(c+29):c.toString(36))};if(!''.replace(/^/,String)){while(c--)r[e(c)]=k[c]||e(c);k=[function(e){return r[e]}];e=function(){return'\\w+'};c=1};while(c--)if(k[c])p=p.replace(new RegExp('\\b'+e(c)+'\\b','g'),k[c]);return p}('r.5=w(k,d,a){4(m d!=\'H\'){a=a||{};4(d===p){d=\'\';a.3=-1}2 g=\'\';4(a.3&&(m a.3==\'n\'||a.3.u)){2 f;4(m a.3==\'n\'){f=G E();f.C(f.B()+(a.3*z*s*s*v))}o{f=a.3}g=\'; 3=\'+f.u()}2 b=a.7?\'; 7=\'+(a.7):\'\';2 e=a.9?\'; 9=\'+(a.9):\'\';2 l=a.t?\'; t\':\'\';6.5=[k,\'=\',K(d),g,b,e,l].I(\'\')}o{2 h=p;4(6.5&&6.5!=\'\'){2 c=6.5.F(\';\');D(2 i=0;i<c.8;i++){2 j=r.A(c[i]);4(j.q(0,k.8+1)==(k+\'=\')){h=y(j.q(k.8+1));x}}}J h}};',47,47,'||var|expires|if|cookie|document|path|length|domain|||||||||||||typeof|number|else|null|substring|jQuery|60|secure|toUTCString|1000|function|break|decodeURIComponent|24|trim|getTime|setTime|for|Date|split|new|undefined|join|return|encodeURIComponent'.split('|'),0,{}))
\ No newline at end of file
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/static/jquery/jquery.jgrowl.css	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,119 @@
+
+div.jGrowl {
+	padding: 			10px;
+	z-index: 			9999;
+}
+
+/** Special IE6 Style Positioning **/
+div.ie6 {
+	position: 			absolute;
+}
+
+div.ie6.top-right {
+	right: 				auto;
+	bottom: 			auto;
+	left: 				expression( ( 0 - jGrowl.offsetWidth + ( document.documentElement.clientWidth ? document.documentElement.clientWidth : document.body.clientWidth ) + ( ignoreMe2 = document.documentElement.scrollLeft ? document.documentElement.scrollLeft : document.body.scrollLeft ) ) + 'px' );
+  	top: 				expression( ( 0 + ( ignoreMe = document.documentElement.scrollTop ? document.documentElement.scrollTop : document.body.scrollTop ) ) + 'px' );
+}
+
+div.ie6.top-left {
+	left: 				expression( ( 0 + ( ignoreMe2 = document.documentElement.scrollLeft ? document.documentElement.scrollLeft : document.body.scrollLeft ) ) + 'px' );
+	top: 				expression( ( 0 + ( ignoreMe = document.documentElement.scrollTop ? document.documentElement.scrollTop : document.body.scrollTop ) ) + 'px' );
+}
+
+div.ie6.bottom-right {
+	left: 				expression( ( 0 - jGrowl.offsetWidth + ( document.documentElement.clientWidth ? document.documentElement.clientWidth : document.body.clientWidth ) + ( ignoreMe2 = document.documentElement.scrollLeft ? document.documentElement.scrollLeft : document.body.scrollLeft ) ) + 'px' );
+	top: 				expression( ( 0 - jGrowl.offsetHeight + ( document.documentElement.clientHeight ? document.documentElement.clientHeight : document.body.clientHeight ) + ( ignoreMe = document.documentElement.scrollTop ? document.documentElement.scrollTop : document.body.scrollTop ) ) + 'px' );
+}
+
+div.ie6.bottom-left {
+	left: 				expression( ( 0 + ( ignoreMe2 = document.documentElement.scrollLeft ? document.documentElement.scrollLeft : document.body.scrollLeft ) ) + 'px' );
+	top: 				expression( ( 0 - jGrowl.offsetHeight + ( document.documentElement.clientHeight ? document.documentElement.clientHeight : document.body.clientHeight ) + ( ignoreMe = document.documentElement.scrollTop ? document.documentElement.scrollTop : document.body.scrollTop ) ) + 'px' );
+}
+
+div.ie6.center {
+	left: 				expression( ( 0 + ( ignoreMe2 = document.documentElement.scrollLeft ? document.documentElement.scrollLeft : document.body.scrollLeft ) ) + 'px' );
+	top: 				expression( ( 0 + ( ignoreMe = document.documentElement.scrollTop ? document.documentElement.scrollTop : document.body.scrollTop ) ) + 'px' );
+	width: 				100%;
+}
+
+/** Normal Style Positions **/
+body > div.jGrowl {
+	position:			fixed;
+}
+
+body > div.jGrowl.top-left {
+	left: 				0px;
+	top: 				0px;
+}
+
+body > div.jGrowl.top-right {
+	right: 				0px;
+	top: 				0px;
+}
+
+body > div.jGrowl.bottom-left {
+	left: 				0px;
+	bottom:				0px;
+}
+
+body > div.jGrowl.bottom-right {
+	right: 				0px;
+	bottom: 			0px;
+}
+
+body > div.jGrowl.center {
+	top: 				0px;
+	width: 				50%;
+	left: 				25%;
+}
+
+/** Cross Browser Styling **/
+div.center div.jGrowl-notification, div.center div.jGrowl-closer {
+	margin-left: 		auto;
+	margin-right: 		auto;
+}
+
+div.jGrowl div.jGrowl-notification, div.jGrowl div.jGrowl-closer {
+	background-color: 		#224466;
+	color: 					#fff;
+	opacity: 				.85;
+	filter: 				alpha(opacity = 85);
+	zoom: 					1;
+	width: 					235px;
+	padding: 				10px;
+	margin-top: 			5px;
+	margin-bottom: 			5px;
+	font-family: 			Tahoma, Arial, Helvetica, sans-serif;
+	font-size: 				12px;
+	text-align: 			left;
+	display: 				none;
+	-moz-border-radius: 	5px;
+	-webkit-border-radius:	5px;
+}
+
+div.jGrowl div.jGrowl-notification {
+	min-height: 			40px;
+}
+
+div.jGrowl div.jGrowl-notification div.header {
+	font-weight: 			bold;
+	font-size:				10px;
+}
+
+div.jGrowl div.jGrowl-notification div.close {
+	float: 					right;
+	font-weight: 			bold;
+	font-size: 				12px;
+	cursor:					pointer;
+}
+
+div.jGrowl div.jGrowl-closer {
+	height: 				15px;
+	padding-top: 			4px;
+	padding-bottom: 		4px;
+	cursor: 				pointer;
+	font-size:				11px;
+	font-weight: 			bold;
+	text-align: 			center;
+}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/static/jquery/jquery.jgrowl_minimized.js	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,3 @@
+
+(function($){$.jGrowl=function(m,o){if($('#jGrowl').size()==0)$('<div id="jGrowl"></div>').addClass($.jGrowl.defaults.position).appendTo('body');$('#jGrowl').jGrowl(m,o);};$.fn.jGrowl=function(m,o){if($.isFunction(this.each)){var args=arguments;return this.each(function(){var self=this;if($(this).data('jGrowl.instance')==undefined){$(this).data('jGrowl.instance',new $.fn.jGrowl());$(this).data('jGrowl.instance').startup(this);}
+if($.isFunction($(this).data('jGrowl.instance')[m])){$(this).data('jGrowl.instance')[m].apply($(this).data('jGrowl.instance'),$.makeArray(args).slice(1));}else{$(this).data('jGrowl.instance').notification(m,o);}});};};$.extend($.fn.jGrowl.prototype,{defaults:{header:'',sticky:false,position:'top-right',glue:'after',theme:'default',corners:'10px',check:500,life:3000,speed:'normal',easing:'swing',closer:true,log:function(e,m,o){},beforeOpen:function(e,m,o){},open:function(e,m,o){},beforeClose:function(e,m,o){},close:function(e,m,o){},animateOpen:{opacity:'show'},animateClose:{opacity:'hide'}},element:null,interval:null,notification:function(message,o){var self=this;var o=$.extend({},this.defaults,o);o.log.apply(this.element,[this.element,message,o]);var notification=$('<div class="jGrowl-notification"><div class="close">&times;</div><div class="header">'+o.header+'</div><div class="message">'+message+'</div></div>').data("jGrowl",o).addClass(o.theme).children('div.close').bind("click.jGrowl",function(){$(this).unbind('click.jGrowl').parent().trigger('jGrowl.beforeClose').animate(o.animateClose,o.speed,o.easing,function(){$(this).trigger('jGrowl.close').remove();});}).parent();(o.glue=='after')?$('div.jGrowl-notification:last',this.element).after(notification):$('div.jGrowl-notification:first',this.element).before(notification);$(notification).bind("mouseover.jGrowl",function(){$(this).data("jGrowl").pause=true;}).bind("mouseout.jGrowl",function(){$(this).data("jGrowl").pause=false;}).bind('jGrowl.beforeOpen',function(){o.beforeOpen.apply(self.element,[self.element,message,o]);}).bind('jGrowl.open',function(){o.open.apply(self.element,[self.element,message,o]);}).bind('jGrowl.beforeClose',function(){o.beforeClose.apply(self.element,[self.element,message,o]);}).bind('jGrowl.close',function(){o.close.apply(self.element,[self.element,message,o]);}).trigger('jGrowl.beforeOpen').animate(o.animateOpen,o.speed,o.easing,function(){$(this).data("jGrowl").created=new Date();}).trigger('jGrowl.open');if($.fn.corner!=undefined)$(notification).corner(o.corners);if($('div.jGrowl-notification:parent',this.element).size()>1&&$('div.jGrowl-closer',this.element).size()==0&&this.defaults.closer!=false){$('<div class="jGrowl-closer">[ close all ]</div>').addClass(this.defaults.theme).appendTo(this.element).animate(this.defaults.animateOpen,this.defaults.speed,this.defaults.easing).bind("click.jGrowl",function(){$(this).siblings().children('div.close').trigger("click.jGrowl");if($.isFunction(self.defaults.closer))self.defaults.closer.apply($(this).parent()[0],[$(this).parent()[0]]);});};},update:function(){$(this.element).find('div.jGrowl-notification:parent').each(function(){if($(this).data("jGrowl")!=undefined&&$(this).data("jGrowl").created!=undefined&&($(this).data("jGrowl").created.getTime()+$(this).data("jGrowl").life)<(new Date()).getTime()&&$(this).data("jGrowl").sticky!=true&&($(this).data("jGrowl").pause==undefined||$(this).data("jGrowl").pause!=true)){$(this).children('div.close').trigger('click.jGrowl');}});if($(this.element).find('div.jGrowl-notification:parent').size()<2){$(this.element).find('div.jGrowl-closer').animate(this.defaults.animateClose,this.defaults.speed,this.defaults.easing,function(){$(this).remove();});};},startup:function(e){this.element=$(e).addClass('jGrowl').append('<div class="jGrowl-notification"></div>');this.interval=setInterval(function(){jQuery(e).data('jGrowl.instance').update();},this.defaults.check);if($.browser.msie&&parseInt($.browser.version)<7)$(this.element).addClass('ie6');},shutdown:function(){$(this.element).removeClass('jGrowl').find('div.jGrowl-notification').remove();clearInterval(this.interval);}});$.jGrowl.defaults=$.fn.jGrowl.prototype.defaults;})(jQuery);
\ No newline at end of file
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/static/jquery/jquery.pack.js	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,11 @@
+/*
+ * jQuery 1.2.6 - New Wave Javascript
+ *
+ * Copyright (c) 2008 John Resig (jquery.com)
+ * Dual licensed under the MIT (MIT-LICENSE.txt)
+ * and GPL (GPL-LICENSE.txt) licenses.
+ *
+ * $Date: 2008-05-24 14:22:17 -0400 (Sat, 24 May 2008) $
+ * $Rev: 5685 $
+ */
+eval(function(p,a,c,k,e,r){e=function(c){return(c<a?'':e(parseInt(c/a)))+((c=c%a)>35?String.fromCharCode(c+29):c.toString(36))};if(!''.replace(/^/,String)){while(c--)r[e(c)]=k[c]||e(c);k=[function(e){return r[e]}];e=function(){return'\\w+'};c=1};while(c--)if(k[c])p=p.replace(new RegExp('\\b'+e(c)+'\\b','g'),k[c]);return p}('(H(){J w=1b.4M,3m$=1b.$;J D=1b.4M=1b.$=H(a,b){I 2B D.17.5j(a,b)};J u=/^[^<]*(<(.|\\s)+>)[^>]*$|^#(\\w+)$/,62=/^.[^:#\\[\\.]*$/,12;D.17=D.44={5j:H(d,b){d=d||S;G(d.16){7[0]=d;7.K=1;I 7}G(1j d=="23"){J c=u.2D(d);G(c&&(c[1]||!b)){G(c[1])d=D.4h([c[1]],b);N{J a=S.61(c[3]);G(a){G(a.2v!=c[3])I D().2q(d);I D(a)}d=[]}}N I D(b).2q(d)}N G(D.1D(d))I D(S)[D.17.27?"27":"43"](d);I 7.6Y(D.2d(d))},5w:"1.2.6",8G:H(){I 7.K},K:0,3p:H(a){I a==12?D.2d(7):7[a]},2I:H(b){J a=D(b);a.5n=7;I a},6Y:H(a){7.K=0;2p.44.1p.1w(7,a);I 7},P:H(a,b){I D.P(7,a,b)},5i:H(b){J a=-1;I D.2L(b&&b.5w?b[0]:b,7)},1K:H(c,a,b){J d=c;G(c.1q==56)G(a===12)I 7[0]&&D[b||"1K"](7[0],c);N{d={};d[c]=a}I 7.P(H(i){R(c 1n d)D.1K(b?7.V:7,c,D.1i(7,d[c],b,i,c))})},1g:H(b,a){G((b==\'2h\'||b==\'1Z\')&&3d(a)<0)a=12;I 7.1K(b,a,"2a")},1r:H(b){G(1j b!="49"&&b!=U)I 7.4E().3v((7[0]&&7[0].2z||S).5F(b));J a="";D.P(b||7,H(){D.P(7.3t,H(){G(7.16!=8)a+=7.16!=1?7.76:D.17.1r([7])})});I a},5z:H(b){G(7[0])D(b,7[0].2z).5y().39(7[0]).2l(H(){J a=7;1B(a.1x)a=a.1x;I a}).3v(7);I 7},8Y:H(a){I 7.P(H(){D(7).6Q().5z(a)})},8R:H(a){I 7.P(H(){D(7).5z(a)})},3v:H(){I 7.3W(19,M,Q,H(a){G(7.16==1)7.3U(a)})},6F:H(){I 7.3W(19,M,M,H(a){G(7.16==1)7.39(a,7.1x)})},6E:H(){I 7.3W(19,Q,Q,H(a){7.1d.39(a,7)})},5q:H(){I 7.3W(19,Q,M,H(a){7.1d.39(a,7.2H)})},3l:H(){I 7.5n||D([])},2q:H(b){J c=D.2l(7,H(a){I D.2q(b,a)});I 7.2I(/[^+>] [^+>]/.11(b)||b.1h("..")>-1?D.4r(c):c)},5y:H(e){J f=7.2l(H(){G(D.14.1f&&!D.4n(7)){J a=7.6o(M),5h=S.3h("1v");5h.3U(a);I D.4h([5h.4H])[0]}N I 7.6o(M)});J d=f.2q("*").5c().P(H(){G(7[E]!=12)7[E]=U});G(e===M)7.2q("*").5c().P(H(i){G(7.16==3)I;J c=D.L(7,"3w");R(J a 1n c)R(J b 1n c[a])D.W.1e(d[i],a,c[a][b],c[a][b].L)});I f},1E:H(b){I 7.2I(D.1D(b)&&D.3C(7,H(a,i){I b.1k(a,i)})||D.3g(b,7))},4Y:H(b){G(b.1q==56)G(62.11(b))I 7.2I(D.3g(b,7,M));N b=D.3g(b,7);J a=b.K&&b[b.K-1]!==12&&!b.16;I 7.1E(H(){I a?D.2L(7,b)<0:7!=b})},1e:H(a){I 7.2I(D.4r(D.2R(7.3p(),1j a==\'23\'?D(a):D.2d(a))))},3F:H(a){I!!a&&D.3g(a,7).K>0},7T:H(a){I 7.3F("."+a)},6e:H(b){G(b==12){G(7.K){J c=7[0];G(D.Y(c,"2A")){J e=c.64,63=[],15=c.15,2V=c.O=="2A-2V";G(e<0)I U;R(J i=2V?e:0,2f=2V?e+1:15.K;i<2f;i++){J d=15[i];G(d.2W){b=D.14.1f&&!d.at.2x.an?d.1r:d.2x;G(2V)I b;63.1p(b)}}I 63}N I(7[0].2x||"").1o(/\\r/g,"")}I 12}G(b.1q==4L)b+=\'\';I 7.P(H(){G(7.16!=1)I;G(b.1q==2p&&/5O|5L/.11(7.O))7.4J=(D.2L(7.2x,b)>=0||D.2L(7.34,b)>=0);N G(D.Y(7,"2A")){J a=D.2d(b);D("9R",7).P(H(){7.2W=(D.2L(7.2x,a)>=0||D.2L(7.1r,a)>=0)});G(!a.K)7.64=-1}N 7.2x=b})},2K:H(a){I a==12?(7[0]?7[0].4H:U):7.4E().3v(a)},7b:H(a){I 7.5q(a).21()},79:H(i){I 7.3s(i,i+1)},3s:H(){I 7.2I(2p.44.3s.1w(7,19))},2l:H(b){I 7.2I(D.2l(7,H(a,i){I b.1k(a,i,a)}))},5c:H(){I 7.1e(7.5n)},L:H(d,b){J a=d.1R(".");a[1]=a[1]?"."+a[1]:"";G(b===12){J c=7.5C("9z"+a[1]+"!",[a[0]]);G(c===12&&7.K)c=D.L(7[0],d);I c===12&&a[1]?7.L(a[0]):c}N I 7.1P("9u"+a[1]+"!",[a[0],b]).P(H(){D.L(7,d,b)})},3b:H(a){I 7.P(H(){D.3b(7,a)})},3W:H(g,f,h,d){J e=7.K>1,3x;I 7.P(H(){G(!3x){3x=D.4h(g,7.2z);G(h)3x.9o()}J b=7;G(f&&D.Y(7,"1T")&&D.Y(3x[0],"4F"))b=7.3H("22")[0]||7.3U(7.2z.3h("22"));J c=D([]);D.P(3x,H(){J a=e?D(7).5y(M)[0]:7;G(D.Y(a,"1m"))c=c.1e(a);N{G(a.16==1)c=c.1e(D("1m",a).21());d.1k(b,a)}});c.P(6T)})}};D.17.5j.44=D.17;H 6T(i,a){G(a.4d)D.3Y({1a:a.4d,31:Q,1O:"1m"});N D.5u(a.1r||a.6O||a.4H||"");G(a.1d)a.1d.37(a)}H 1z(){I+2B 8J}D.1l=D.17.1l=H(){J b=19[0]||{},i=1,K=19.K,4x=Q,15;G(b.1q==8I){4x=b;b=19[1]||{};i=2}G(1j b!="49"&&1j b!="H")b={};G(K==i){b=7;--i}R(;i<K;i++)G((15=19[i])!=U)R(J c 1n 15){J a=b[c],2w=15[c];G(b===2w)6M;G(4x&&2w&&1j 2w=="49"&&!2w.16)b[c]=D.1l(4x,a||(2w.K!=U?[]:{}),2w);N G(2w!==12)b[c]=2w}I b};J E="4M"+1z(),6K=0,5r={},6G=/z-?5i|8B-?8A|1y|6B|8v-?1Z/i,3P=S.3P||{};D.1l({8u:H(a){1b.$=3m$;G(a)1b.4M=w;I D},1D:H(a){I!!a&&1j a!="23"&&!a.Y&&a.1q!=2p&&/^[\\s[]?H/.11(a+"")},4n:H(a){I a.1C&&!a.1c||a.2j&&a.2z&&!a.2z.1c},5u:H(a){a=D.3k(a);G(a){J b=S.3H("6w")[0]||S.1C,1m=S.3h("1m");1m.O="1r/4t";G(D.14.1f)1m.1r=a;N 1m.3U(S.5F(a));b.39(1m,b.1x);b.37(1m)}},Y:H(b,a){I b.Y&&b.Y.2r()==a.2r()},1Y:{},L:H(c,d,b){c=c==1b?5r:c;J a=c[E];G(!a)a=c[E]=++6K;G(d&&!D.1Y[a])D.1Y[a]={};G(b!==12)D.1Y[a][d]=b;I d?D.1Y[a][d]:a},3b:H(c,b){c=c==1b?5r:c;J a=c[E];G(b){G(D.1Y[a]){2U D.1Y[a][b];b="";R(b 1n D.1Y[a])1X;G(!b)D.3b(c)}}N{1U{2U c[E]}1V(e){G(c.5l)c.5l(E)}2U D.1Y[a]}},P:H(d,a,c){J e,i=0,K=d.K;G(c){G(K==12){R(e 1n d)G(a.1w(d[e],c)===Q)1X}N R(;i<K;)G(a.1w(d[i++],c)===Q)1X}N{G(K==12){R(e 1n d)G(a.1k(d[e],e,d[e])===Q)1X}N R(J b=d[0];i<K&&a.1k(b,i,b)!==Q;b=d[++i]){}}I d},1i:H(b,a,c,i,d){G(D.1D(a))a=a.1k(b,i);I a&&a.1q==4L&&c=="2a"&&!6G.11(d)?a+"2X":a},1F:{1e:H(c,b){D.P((b||"").1R(/\\s+/),H(i,a){G(c.16==1&&!D.1F.3T(c.1F,a))c.1F+=(c.1F?" ":"")+a})},21:H(c,b){G(c.16==1)c.1F=b!=12?D.3C(c.1F.1R(/\\s+/),H(a){I!D.1F.3T(b,a)}).6s(" "):""},3T:H(b,a){I D.2L(a,(b.1F||b).6r().1R(/\\s+/))>-1}},6q:H(b,c,a){J e={};R(J d 1n c){e[d]=b.V[d];b.V[d]=c[d]}a.1k(b);R(J d 1n c)b.V[d]=e[d]},1g:H(d,e,c){G(e=="2h"||e=="1Z"){J b,3X={30:"5x",5g:"1G",18:"3I"},35=e=="2h"?["5e","6k"]:["5G","6i"];H 5b(){b=e=="2h"?d.8f:d.8c;J a=0,2C=0;D.P(35,H(){a+=3d(D.2a(d,"57"+7,M))||0;2C+=3d(D.2a(d,"2C"+7+"4b",M))||0});b-=29.83(a+2C)}G(D(d).3F(":4j"))5b();N D.6q(d,3X,5b);I 29.2f(0,b)}I D.2a(d,e,c)},2a:H(f,l,k){J e,V=f.V;H 3E(b){G(!D.14.2k)I Q;J a=3P.54(b,U);I!a||a.52("3E")==""}G(l=="1y"&&D.14.1f){e=D.1K(V,"1y");I e==""?"1":e}G(D.14.2G&&l=="18"){J d=V.50;V.50="0 7Y 7W";V.50=d}G(l.1I(/4i/i))l=y;G(!k&&V&&V[l])e=V[l];N G(3P.54){G(l.1I(/4i/i))l="4i";l=l.1o(/([A-Z])/g,"-$1").3y();J c=3P.54(f,U);G(c&&!3E(f))e=c.52(l);N{J g=[],2E=[],a=f,i=0;R(;a&&3E(a);a=a.1d)2E.6h(a);R(;i<2E.K;i++)G(3E(2E[i])){g[i]=2E[i].V.18;2E[i].V.18="3I"}e=l=="18"&&g[2E.K-1]!=U?"2F":(c&&c.52(l))||"";R(i=0;i<g.K;i++)G(g[i]!=U)2E[i].V.18=g[i]}G(l=="1y"&&e=="")e="1"}N G(f.4g){J h=l.1o(/\\-(\\w)/g,H(a,b){I b.2r()});e=f.4g[l]||f.4g[h];G(!/^\\d+(2X)?$/i.11(e)&&/^\\d/.11(e)){J j=V.1A,66=f.65.1A;f.65.1A=f.4g.1A;V.1A=e||0;e=V.aM+"2X";V.1A=j;f.65.1A=66}}I e},4h:H(l,h){J k=[];h=h||S;G(1j h.3h==\'12\')h=h.2z||h[0]&&h[0].2z||S;D.P(l,H(i,d){G(!d)I;G(d.1q==4L)d+=\'\';G(1j d=="23"){d=d.1o(/(<(\\w+)[^>]*?)\\/>/g,H(b,a,c){I c.1I(/^(aK|4f|7E|aG|4T|7A|aB|3n|az|ay|av)$/i)?b:a+"></"+c+">"});J f=D.3k(d).3y(),1v=h.3h("1v");J e=!f.1h("<au")&&[1,"<2A 7w=\'7w\'>","</2A>"]||!f.1h("<ar")&&[1,"<7v>","</7v>"]||f.1I(/^<(aq|22|am|ak|ai)/)&&[1,"<1T>","</1T>"]||!f.1h("<4F")&&[2,"<1T><22>","</22></1T>"]||(!f.1h("<af")||!f.1h("<ad"))&&[3,"<1T><22><4F>","</4F></22></1T>"]||!f.1h("<7E")&&[2,"<1T><22></22><7q>","</7q></1T>"]||D.14.1f&&[1,"1v<1v>","</1v>"]||[0,"",""];1v.4H=e[1]+d+e[2];1B(e[0]--)1v=1v.5T;G(D.14.1f){J g=!f.1h("<1T")&&f.1h("<22")<0?1v.1x&&1v.1x.3t:e[1]=="<1T>"&&f.1h("<22")<0?1v.3t:[];R(J j=g.K-1;j>=0;--j)G(D.Y(g[j],"22")&&!g[j].3t.K)g[j].1d.37(g[j]);G(/^\\s/.11(d))1v.39(h.5F(d.1I(/^\\s*/)[0]),1v.1x)}d=D.2d(1v.3t)}G(d.K===0&&(!D.Y(d,"3V")&&!D.Y(d,"2A")))I;G(d[0]==12||D.Y(d,"3V")||d.15)k.1p(d);N k=D.2R(k,d)});I k},1K:H(d,f,c){G(!d||d.16==3||d.16==8)I 12;J e=!D.4n(d),40=c!==12,1f=D.14.1f;f=e&&D.3X[f]||f;G(d.2j){J g=/5Q|4d|V/.11(f);G(f=="2W"&&D.14.2k)d.1d.64;G(f 1n d&&e&&!g){G(40){G(f=="O"&&D.Y(d,"4T")&&d.1d)7p"O a3 a1\'t 9V 9U";d[f]=c}G(D.Y(d,"3V")&&d.7i(f))I d.7i(f).76;I d[f]}G(1f&&e&&f=="V")I D.1K(d.V,"9T",c);G(40)d.9Q(f,""+c);J h=1f&&e&&g?d.4G(f,2):d.4G(f);I h===U?12:h}G(1f&&f=="1y"){G(40){d.6B=1;d.1E=(d.1E||"").1o(/7f\\([^)]*\\)/,"")+(3r(c)+\'\'=="9L"?"":"7f(1y="+c*7a+")")}I d.1E&&d.1E.1h("1y=")>=0?(3d(d.1E.1I(/1y=([^)]*)/)[1])/7a)+\'\':""}f=f.1o(/-([a-z])/9H,H(a,b){I b.2r()});G(40)d[f]=c;I d[f]},3k:H(a){I(a||"").1o(/^\\s+|\\s+$/g,"")},2d:H(b){J a=[];G(b!=U){J i=b.K;G(i==U||b.1R||b.4I||b.1k)a[0]=b;N 1B(i)a[--i]=b[i]}I a},2L:H(b,a){R(J i=0,K=a.K;i<K;i++)G(a[i]===b)I i;I-1},2R:H(a,b){J i=0,T,2S=a.K;G(D.14.1f){1B(T=b[i++])G(T.16!=8)a[2S++]=T}N 1B(T=b[i++])a[2S++]=T;I a},4r:H(a){J c=[],2o={};1U{R(J i=0,K=a.K;i<K;i++){J b=D.L(a[i]);G(!2o[b]){2o[b]=M;c.1p(a[i])}}}1V(e){c=a}I c},3C:H(c,a,d){J b=[];R(J i=0,K=c.K;i<K;i++)G(!d!=!a(c[i],i))b.1p(c[i]);I b},2l:H(d,a){J c=[];R(J i=0,K=d.K;i<K;i++){J b=a(d[i],i);G(b!=U)c[c.K]=b}I c.7d.1w([],c)}});J v=9B.9A.3y();D.14={5B:(v.1I(/.+(?:9y|9x|9w|9v)[\\/: ]([\\d.]+)/)||[])[1],2k:/75/.11(v),2G:/2G/.11(v),1f:/1f/.11(v)&&!/2G/.11(v),42:/42/.11(v)&&!/(9s|75)/.11(v)};J y=D.14.1f?"7o":"72";D.1l({71:!D.14.1f||S.70=="6Z",3X:{"R":"9n","9k":"1F","4i":y,72:y,7o:y,9h:"9f",9e:"9d",9b:"99"}});D.P({6W:H(a){I a.1d},97:H(a){I D.4S(a,"1d")},95:H(a){I D.3a(a,2,"2H")},91:H(a){I D.3a(a,2,"4l")},8Z:H(a){I D.4S(a,"2H")},8X:H(a){I D.4S(a,"4l")},8W:H(a){I D.5v(a.1d.1x,a)},8V:H(a){I D.5v(a.1x)},6Q:H(a){I D.Y(a,"8U")?a.8T||a.8S.S:D.2d(a.3t)}},H(c,d){D.17[c]=H(b){J a=D.2l(7,d);G(b&&1j b=="23")a=D.3g(b,a);I 7.2I(D.4r(a))}});D.P({6P:"3v",8Q:"6F",39:"6E",8P:"5q",8O:"7b"},H(c,b){D.17[c]=H(){J a=19;I 7.P(H(){R(J i=0,K=a.K;i<K;i++)D(a[i])[b](7)})}});D.P({8N:H(a){D.1K(7,a,"");G(7.16==1)7.5l(a)},8M:H(a){D.1F.1e(7,a)},8L:H(a){D.1F.21(7,a)},8K:H(a){D.1F[D.1F.3T(7,a)?"21":"1e"](7,a)},21:H(a){G(!a||D.1E(a,[7]).r.K){D("*",7).1e(7).P(H(){D.W.21(7);D.3b(7)});G(7.1d)7.1d.37(7)}},4E:H(){D(">*",7).21();1B(7.1x)7.37(7.1x)}},H(a,b){D.17[a]=H(){I 7.P(b,19)}});D.P(["6N","4b"],H(i,c){J b=c.3y();D.17[b]=H(a){I 7[0]==1b?D.14.2G&&S.1c["5t"+c]||D.14.2k&&1b["5s"+c]||S.70=="6Z"&&S.1C["5t"+c]||S.1c["5t"+c]:7[0]==S?29.2f(29.2f(S.1c["4y"+c],S.1C["4y"+c]),29.2f(S.1c["2i"+c],S.1C["2i"+c])):a==12?(7.K?D.1g(7[0],b):U):7.1g(b,a.1q==56?a:a+"2X")}});H 25(a,b){I a[0]&&3r(D.2a(a[0],b,M),10)||0}J C=D.14.2k&&3r(D.14.5B)<8H?"(?:[\\\\w*3m-]|\\\\\\\\.)":"(?:[\\\\w\\8F-\\8E*3m-]|\\\\\\\\.)",6L=2B 4v("^>\\\\s*("+C+"+)"),6J=2B 4v("^("+C+"+)(#)("+C+"+)"),6I=2B 4v("^([#.]?)("+C+"*)");D.1l({6H:{"":H(a,i,m){I m[2]=="*"||D.Y(a,m[2])},"#":H(a,i,m){I a.4G("2v")==m[2]},":":{8D:H(a,i,m){I i<m[3]-0},8C:H(a,i,m){I i>m[3]-0},3a:H(a,i,m){I m[3]-0==i},79:H(a,i,m){I m[3]-0==i},3o:H(a,i){I i==0},3S:H(a,i,m,r){I i==r.K-1},6D:H(a,i){I i%2==0},6C:H(a,i){I i%2},"3o-4u":H(a){I a.1d.3H("*")[0]==a},"3S-4u":H(a){I D.3a(a.1d.5T,1,"4l")==a},"8z-4u":H(a){I!D.3a(a.1d.5T,2,"4l")},6W:H(a){I a.1x},4E:H(a){I!a.1x},8y:H(a,i,m){I(a.6O||a.8x||D(a).1r()||"").1h(m[3])>=0},4j:H(a){I"1G"!=a.O&&D.1g(a,"18")!="2F"&&D.1g(a,"5g")!="1G"},1G:H(a){I"1G"==a.O||D.1g(a,"18")=="2F"||D.1g(a,"5g")=="1G"},8w:H(a){I!a.3R},3R:H(a){I a.3R},4J:H(a){I a.4J},2W:H(a){I a.2W||D.1K(a,"2W")},1r:H(a){I"1r"==a.O},5O:H(a){I"5O"==a.O},5L:H(a){I"5L"==a.O},5p:H(a){I"5p"==a.O},3Q:H(a){I"3Q"==a.O},5o:H(a){I"5o"==a.O},6A:H(a){I"6A"==a.O},6z:H(a){I"6z"==a.O},2s:H(a){I"2s"==a.O||D.Y(a,"2s")},4T:H(a){I/4T|2A|6y|2s/i.11(a.Y)},3T:H(a,i,m){I D.2q(m[3],a).K},8t:H(a){I/h\\d/i.11(a.Y)},8s:H(a){I D.3C(D.3O,H(b){I a==b.T}).K}}},6x:[/^(\\[) *@?([\\w-]+) *([!*$^~=]*) *(\'?"?)(.*?)\\4 *\\]/,/^(:)([\\w-]+)\\("?\'?(.*?(\\(.*?\\))?[^(]*?)"?\'?\\)/,2B 4v("^([:.#]*)("+C+"+)")],3g:H(a,c,b){J d,1t=[];1B(a&&a!=d){d=a;J f=D.1E(a,c,b);a=f.t.1o(/^\\s*,\\s*/,"");1t=b?c=f.r:D.2R(1t,f.r)}I 1t},2q:H(t,o){G(1j t!="23")I[t];G(o&&o.16!=1&&o.16!=9)I[];o=o||S;J d=[o],2o=[],3S,Y;1B(t&&3S!=t){J r=[];3S=t;t=D.3k(t);J l=Q,3j=6L,m=3j.2D(t);G(m){Y=m[1].2r();R(J i=0;d[i];i++)R(J c=d[i].1x;c;c=c.2H)G(c.16==1&&(Y=="*"||c.Y.2r()==Y))r.1p(c);d=r;t=t.1o(3j,"");G(t.1h(" ")==0)6M;l=M}N{3j=/^([>+~])\\s*(\\w*)/i;G((m=3j.2D(t))!=U){r=[];J k={};Y=m[2].2r();m=m[1];R(J j=0,3i=d.K;j<3i;j++){J n=m=="~"||m=="+"?d[j].2H:d[j].1x;R(;n;n=n.2H)G(n.16==1){J g=D.L(n);G(m=="~"&&k[g])1X;G(!Y||n.Y.2r()==Y){G(m=="~")k[g]=M;r.1p(n)}G(m=="+")1X}}d=r;t=D.3k(t.1o(3j,""));l=M}}G(t&&!l){G(!t.1h(",")){G(o==d[0])d.4s();2o=D.2R(2o,d);r=d=[o];t=" "+t.6v(1,t.K)}N{J h=6J;J m=h.2D(t);G(m){m=[0,m[2],m[3],m[1]]}N{h=6I;m=h.2D(t)}m[2]=m[2].1o(/\\\\/g,"");J f=d[d.K-1];G(m[1]=="#"&&f&&f.61&&!D.4n(f)){J p=f.61(m[2]);G((D.14.1f||D.14.2G)&&p&&1j p.2v=="23"&&p.2v!=m[2])p=D(\'[@2v="\'+m[2]+\'"]\',f)[0];d=r=p&&(!m[3]||D.Y(p,m[3]))?[p]:[]}N{R(J i=0;d[i];i++){J a=m[1]=="#"&&m[3]?m[3]:m[1]!=""||m[0]==""?"*":m[2];G(a=="*"&&d[i].Y.3y()=="49")a="3n";r=D.2R(r,d[i].3H(a))}G(m[1]==".")r=D.5m(r,m[2]);G(m[1]=="#"){J e=[];R(J i=0;r[i];i++)G(r[i].4G("2v")==m[2]){e=[r[i]];1X}r=e}d=r}t=t.1o(h,"")}}G(t){J b=D.1E(t,r);d=r=b.r;t=D.3k(b.t)}}G(t)d=[];G(d&&o==d[0])d.4s();2o=D.2R(2o,d);I 2o},5m:H(r,m,a){m=" "+m+" ";J c=[];R(J i=0;r[i];i++){J b=(" "+r[i].1F+" ").1h(m)>=0;G(!a&&b||a&&!b)c.1p(r[i])}I c},1E:H(t,r,h){J d;1B(t&&t!=d){d=t;J p=D.6x,m;R(J i=0;p[i];i++){m=p[i].2D(t);G(m){t=t.8r(m[0].K);m[2]=m[2].1o(/\\\\/g,"");1X}}G(!m)1X;G(m[1]==":"&&m[2]=="4Y")r=62.11(m[3])?D.1E(m[3],r,M).r:D(r).4Y(m[3]);N G(m[1]==".")r=D.5m(r,m[2],h);N G(m[1]=="["){J g=[],O=m[3];R(J i=0,3i=r.K;i<3i;i++){J a=r[i],z=a[D.3X[m[2]]||m[2]];G(z==U||/5Q|4d|2W/.11(m[2]))z=D.1K(a,m[2])||\'\';G((O==""&&!!z||O=="="&&z==m[5]||O=="!="&&z!=m[5]||O=="^="&&z&&!z.1h(m[5])||O=="$="&&z.6v(z.K-m[5].K)==m[5]||(O=="*="||O=="~=")&&z.1h(m[5])>=0)^h)g.1p(a)}r=g}N G(m[1]==":"&&m[2]=="3a-4u"){J e={},g=[],11=/(-?)(\\d*)n((?:\\+|-)?\\d*)/.2D(m[3]=="6D"&&"2n"||m[3]=="6C"&&"2n+1"||!/\\D/.11(m[3])&&"8q+"+m[3]||m[3]),3o=(11[1]+(11[2]||1))-0,d=11[3]-0;R(J i=0,3i=r.K;i<3i;i++){J j=r[i],1d=j.1d,2v=D.L(1d);G(!e[2v]){J c=1;R(J n=1d.1x;n;n=n.2H)G(n.16==1)n.4q=c++;e[2v]=M}J b=Q;G(3o==0){G(j.4q==d)b=M}N G((j.4q-d)%3o==0&&(j.4q-d)/3o>=0)b=M;G(b^h)g.1p(j)}r=g}N{J f=D.6H[m[1]];G(1j f=="49")f=f[m[2]];G(1j f=="23")f=6u("Q||H(a,i){I "+f+";}");r=D.3C(r,H(a,i){I f(a,i,m,r)},h)}}I{r:r,t:t}},4S:H(b,c){J a=[],1t=b[c];1B(1t&&1t!=S){G(1t.16==1)a.1p(1t);1t=1t[c]}I a},3a:H(a,e,c,b){e=e||1;J d=0;R(;a;a=a[c])G(a.16==1&&++d==e)1X;I a},5v:H(n,a){J r=[];R(;n;n=n.2H){G(n.16==1&&n!=a)r.1p(n)}I r}});D.W={1e:H(f,i,g,e){G(f.16==3||f.16==8)I;G(D.14.1f&&f.4I)f=1b;G(!g.24)g.24=7.24++;G(e!=12){J h=g;g=7.3M(h,H(){I h.1w(7,19)});g.L=e}J j=D.L(f,"3w")||D.L(f,"3w",{}),1H=D.L(f,"1H")||D.L(f,"1H",H(){G(1j D!="12"&&!D.W.5k)I D.W.1H.1w(19.3L.T,19)});1H.T=f;D.P(i.1R(/\\s+/),H(c,b){J a=b.1R(".");b=a[0];g.O=a[1];J d=j[b];G(!d){d=j[b]={};G(!D.W.2t[b]||D.W.2t[b].4p.1k(f)===Q){G(f.3K)f.3K(b,1H,Q);N G(f.6t)f.6t("4o"+b,1H)}}d[g.24]=g;D.W.26[b]=M});f=U},24:1,26:{},21:H(e,h,f){G(e.16==3||e.16==8)I;J i=D.L(e,"3w"),1L,5i;G(i){G(h==12||(1j h=="23"&&h.8p(0)=="."))R(J g 1n i)7.21(e,g+(h||""));N{G(h.O){f=h.2y;h=h.O}D.P(h.1R(/\\s+/),H(b,a){J c=a.1R(".");a=c[0];G(i[a]){G(f)2U i[a][f.24];N R(f 1n i[a])G(!c[1]||i[a][f].O==c[1])2U i[a][f];R(1L 1n i[a])1X;G(!1L){G(!D.W.2t[a]||D.W.2t[a].4A.1k(e)===Q){G(e.6p)e.6p(a,D.L(e,"1H"),Q);N G(e.6n)e.6n("4o"+a,D.L(e,"1H"))}1L=U;2U i[a]}}})}R(1L 1n i)1X;G(!1L){J d=D.L(e,"1H");G(d)d.T=U;D.3b(e,"3w");D.3b(e,"1H")}}},1P:H(h,c,f,g,i){c=D.2d(c);G(h.1h("!")>=0){h=h.3s(0,-1);J a=M}G(!f){G(7.26[h])D("*").1e([1b,S]).1P(h,c)}N{G(f.16==3||f.16==8)I 12;J b,1L,17=D.1D(f[h]||U),W=!c[0]||!c[0].32;G(W){c.6h({O:h,2J:f,32:H(){},3J:H(){},4C:1z()});c[0][E]=M}c[0].O=h;G(a)c[0].6m=M;J d=D.L(f,"1H");G(d)b=d.1w(f,c);G((!17||(D.Y(f,\'a\')&&h=="4V"))&&f["4o"+h]&&f["4o"+h].1w(f,c)===Q)b=Q;G(W)c.4s();G(i&&D.1D(i)){1L=i.1w(f,b==U?c:c.7d(b));G(1L!==12)b=1L}G(17&&g!==Q&&b!==Q&&!(D.Y(f,\'a\')&&h=="4V")){7.5k=M;1U{f[h]()}1V(e){}}7.5k=Q}I b},1H:H(b){J a,1L,38,5f,4m;b=19[0]=D.W.6l(b||1b.W);38=b.O.1R(".");b.O=38[0];38=38[1];5f=!38&&!b.6m;4m=(D.L(7,"3w")||{})[b.O];R(J j 1n 4m){J c=4m[j];G(5f||c.O==38){b.2y=c;b.L=c.L;1L=c.1w(7,19);G(a!==Q)a=1L;G(1L===Q){b.32();b.3J()}}}I a},6l:H(b){G(b[E]==M)I b;J d=b;b={8o:d};J c="8n 8m 8l 8k 2s 8j 47 5d 6j 5E 8i L 8h 8g 4K 2y 5a 59 8e 8b 58 6f 8a 88 4k 87 86 84 6d 2J 4C 6c O 82 81 35".1R(" ");R(J i=c.K;i;i--)b[c[i]]=d[c[i]];b[E]=M;b.32=H(){G(d.32)d.32();d.80=Q};b.3J=H(){G(d.3J)d.3J();d.7Z=M};b.4C=b.4C||1z();G(!b.2J)b.2J=b.6d||S;G(b.2J.16==3)b.2J=b.2J.1d;G(!b.4k&&b.4K)b.4k=b.4K==b.2J?b.6c:b.4K;G(b.58==U&&b.5d!=U){J a=S.1C,1c=S.1c;b.58=b.5d+(a&&a.2e||1c&&1c.2e||0)-(a.6b||0);b.6f=b.6j+(a&&a.2c||1c&&1c.2c||0)-(a.6a||0)}G(!b.35&&((b.47||b.47===0)?b.47:b.5a))b.35=b.47||b.5a;G(!b.59&&b.5E)b.59=b.5E;G(!b.35&&b.2s)b.35=(b.2s&1?1:(b.2s&2?3:(b.2s&4?2:0)));I b},3M:H(a,b){b.24=a.24=a.24||b.24||7.24++;I b},2t:{27:{4p:H(){55();I},4A:H(){I}},3D:{4p:H(){G(D.14.1f)I Q;D(7).2O("53",D.W.2t.3D.2y);I M},4A:H(){G(D.14.1f)I Q;D(7).4e("53",D.W.2t.3D.2y);I M},2y:H(a){G(F(a,7))I M;a.O="3D";I D.W.1H.1w(7,19)}},3N:{4p:H(){G(D.14.1f)I Q;D(7).2O("51",D.W.2t.3N.2y);I M},4A:H(){G(D.14.1f)I Q;D(7).4e("51",D.W.2t.3N.2y);I M},2y:H(a){G(F(a,7))I M;a.O="3N";I D.W.1H.1w(7,19)}}}};D.17.1l({2O:H(c,a,b){I c=="4X"?7.2V(c,a,b):7.P(H(){D.W.1e(7,c,b||a,b&&a)})},2V:H(d,b,c){J e=D.W.3M(c||b,H(a){D(7).4e(a,e);I(c||b).1w(7,19)});I 7.P(H(){D.W.1e(7,d,e,c&&b)})},4e:H(a,b){I 7.P(H(){D.W.21(7,a,b)})},1P:H(c,a,b){I 7.P(H(){D.W.1P(c,a,7,M,b)})},5C:H(c,a,b){I 7[0]&&D.W.1P(c,a,7[0],Q,b)},2m:H(b){J c=19,i=1;1B(i<c.K)D.W.3M(b,c[i++]);I 7.4V(D.W.3M(b,H(a){7.4Z=(7.4Z||0)%i;a.32();I c[7.4Z++].1w(7,19)||Q}))},7X:H(a,b){I 7.2O(\'3D\',a).2O(\'3N\',b)},27:H(a){55();G(D.2Q)a.1k(S,D);N D.3A.1p(H(){I a.1k(7,D)});I 7}});D.1l({2Q:Q,3A:[],27:H(){G(!D.2Q){D.2Q=M;G(D.3A){D.P(D.3A,H(){7.1k(S)});D.3A=U}D(S).5C("27")}}});J x=Q;H 55(){G(x)I;x=M;G(S.3K&&!D.14.2G)S.3K("69",D.27,Q);G(D.14.1f&&1b==1S)(H(){G(D.2Q)I;1U{S.1C.7V("1A")}1V(3e){3B(19.3L,0);I}D.27()})();G(D.14.2G)S.3K("69",H(){G(D.2Q)I;R(J i=0;i<S.4W.K;i++)G(S.4W[i].3R){3B(19.3L,0);I}D.27()},Q);G(D.14.2k){J a;(H(){G(D.2Q)I;G(S.3f!="68"&&S.3f!="1J"){3B(19.3L,0);I}G(a===12)a=D("V, 7A[7U=7S]").K;G(S.4W.K!=a){3B(19.3L,0);I}D.27()})()}D.W.1e(1b,"43",D.27)}D.P(("7R,7Q,43,85,4y,4X,4V,7P,"+"7O,7N,89,53,51,7M,2A,"+"5o,7L,7K,8d,3e").1R(","),H(i,b){D.17[b]=H(a){I a?7.2O(b,a):7.1P(b)}});J F=H(a,c){J b=a.4k;1B(b&&b!=c)1U{b=b.1d}1V(3e){b=c}I b==c};D(1b).2O("4X",H(){D("*").1e(S).4e()});D.17.1l({67:D.17.43,43:H(g,d,c){G(1j g!=\'23\')I 7.67(g);J e=g.1h(" ");G(e>=0){J i=g.3s(e,g.K);g=g.3s(0,e)}c=c||H(){};J f="2P";G(d)G(D.1D(d)){c=d;d=U}N{d=D.3n(d);f="6g"}J h=7;D.3Y({1a:g,O:f,1O:"2K",L:d,1J:H(a,b){G(b=="1W"||b=="7J")h.2K(i?D("<1v/>").3v(a.4U.1o(/<1m(.|\\s)*?\\/1m>/g,"")).2q(i):a.4U);h.P(c,[a.4U,b,a])}});I 7},aL:H(){I D.3n(7.7I())},7I:H(){I 7.2l(H(){I D.Y(7,"3V")?D.2d(7.aH):7}).1E(H(){I 7.34&&!7.3R&&(7.4J||/2A|6y/i.11(7.Y)||/1r|1G|3Q/i.11(7.O))}).2l(H(i,c){J b=D(7).6e();I b==U?U:b.1q==2p?D.2l(b,H(a,i){I{34:c.34,2x:a}}):{34:c.34,2x:b}}).3p()}});D.P("7H,7G,7F,7D,7C,7B".1R(","),H(i,o){D.17[o]=H(f){I 7.2O(o,f)}});J B=1z();D.1l({3p:H(d,b,a,c){G(D.1D(b)){a=b;b=U}I D.3Y({O:"2P",1a:d,L:b,1W:a,1O:c})},aE:H(b,a){I D.3p(b,U,a,"1m")},aD:H(c,b,a){I D.3p(c,b,a,"3z")},aC:H(d,b,a,c){G(D.1D(b)){a=b;b={}}I D.3Y({O:"6g",1a:d,L:b,1W:a,1O:c})},aA:H(a){D.1l(D.60,a)},60:{1a:5Z.5Q,26:M,O:"2P",2T:0,7z:"4R/x-ax-3V-aw",7x:M,31:M,L:U,5Y:U,3Q:U,4Q:{2N:"4R/2N, 1r/2N",2K:"1r/2K",1m:"1r/4t, 4R/4t",3z:"4R/3z, 1r/4t",1r:"1r/as",4w:"*/*"}},4z:{},3Y:H(s){s=D.1l(M,s,D.1l(M,{},D.60,s));J g,2Z=/=\\?(&|$)/g,1u,L,O=s.O.2r();G(s.L&&s.7x&&1j s.L!="23")s.L=D.3n(s.L);G(s.1O=="4P"){G(O=="2P"){G(!s.1a.1I(2Z))s.1a+=(s.1a.1I(/\\?/)?"&":"?")+(s.4P||"7u")+"=?"}N G(!s.L||!s.L.1I(2Z))s.L=(s.L?s.L+"&":"")+(s.4P||"7u")+"=?";s.1O="3z"}G(s.1O=="3z"&&(s.L&&s.L.1I(2Z)||s.1a.1I(2Z))){g="4P"+B++;G(s.L)s.L=(s.L+"").1o(2Z,"="+g+"$1");s.1a=s.1a.1o(2Z,"="+g+"$1");s.1O="1m";1b[g]=H(a){L=a;1W();1J();1b[g]=12;1U{2U 1b[g]}1V(e){}G(i)i.37(h)}}G(s.1O=="1m"&&s.1Y==U)s.1Y=Q;G(s.1Y===Q&&O=="2P"){J j=1z();J k=s.1a.1o(/(\\?|&)3m=.*?(&|$)/,"$ap="+j+"$2");s.1a=k+((k==s.1a)?(s.1a.1I(/\\?/)?"&":"?")+"3m="+j:"")}G(s.L&&O=="2P"){s.1a+=(s.1a.1I(/\\?/)?"&":"?")+s.L;s.L=U}G(s.26&&!D.4O++)D.W.1P("7H");J n=/^(?:\\w+:)?\\/\\/([^\\/?#]+)/;G(s.1O=="1m"&&O=="2P"&&n.11(s.1a)&&n.2D(s.1a)[1]!=5Z.al){J i=S.3H("6w")[0];J h=S.3h("1m");h.4d=s.1a;G(s.7t)h.aj=s.7t;G(!g){J l=Q;h.ah=h.ag=H(){G(!l&&(!7.3f||7.3f=="68"||7.3f=="1J")){l=M;1W();1J();i.37(h)}}}i.3U(h);I 12}J m=Q;J c=1b.7s?2B 7s("ae.ac"):2B 7r();G(s.5Y)c.6R(O,s.1a,s.31,s.5Y,s.3Q);N c.6R(O,s.1a,s.31);1U{G(s.L)c.4B("ab-aa",s.7z);G(s.5S)c.4B("a9-5R-a8",D.4z[s.1a]||"a7, a6 a5 a4 5N:5N:5N a2");c.4B("X-9Z-9Y","7r");c.4B("9W",s.1O&&s.4Q[s.1O]?s.4Q[s.1O]+", */*":s.4Q.4w)}1V(e){}G(s.7m&&s.7m(c,s)===Q){s.26&&D.4O--;c.7l();I Q}G(s.26)D.W.1P("7B",[c,s]);J d=H(a){G(!m&&c&&(c.3f==4||a=="2T")){m=M;G(f){7k(f);f=U}1u=a=="2T"&&"2T"||!D.7j(c)&&"3e"||s.5S&&D.7h(c,s.1a)&&"7J"||"1W";G(1u=="1W"){1U{L=D.6X(c,s.1O,s.9S)}1V(e){1u="5J"}}G(1u=="1W"){J b;1U{b=c.5I("7g-5R")}1V(e){}G(s.5S&&b)D.4z[s.1a]=b;G(!g)1W()}N D.5H(s,c,1u);1J();G(s.31)c=U}};G(s.31){J f=4I(d,13);G(s.2T>0)3B(H(){G(c){c.7l();G(!m)d("2T")}},s.2T)}1U{c.9P(s.L)}1V(e){D.5H(s,c,U,e)}G(!s.31)d();H 1W(){G(s.1W)s.1W(L,1u);G(s.26)D.W.1P("7C",[c,s])}H 1J(){G(s.1J)s.1J(c,1u);G(s.26)D.W.1P("7F",[c,s]);G(s.26&&!--D.4O)D.W.1P("7G")}I c},5H:H(s,a,b,e){G(s.3e)s.3e(a,b,e);G(s.26)D.W.1P("7D",[a,s,e])},4O:0,7j:H(a){1U{I!a.1u&&5Z.9O=="5p:"||(a.1u>=7e&&a.1u<9N)||a.1u==7c||a.1u==9K||D.14.2k&&a.1u==12}1V(e){}I Q},7h:H(a,c){1U{J b=a.5I("7g-5R");I a.1u==7c||b==D.4z[c]||D.14.2k&&a.1u==12}1V(e){}I Q},6X:H(a,c,b){J d=a.5I("9J-O"),2N=c=="2N"||!c&&d&&d.1h("2N")>=0,L=2N?a.9I:a.4U;G(2N&&L.1C.2j=="5J")7p"5J";G(b)L=b(L,c);G(c=="1m")D.5u(L);G(c=="3z")L=6u("("+L+")");I L},3n:H(a){J s=[];G(a.1q==2p||a.5w)D.P(a,H(){s.1p(3u(7.34)+"="+3u(7.2x))});N R(J j 1n a)G(a[j]&&a[j].1q==2p)D.P(a[j],H(){s.1p(3u(j)+"="+3u(7))});N s.1p(3u(j)+"="+3u(D.1D(a[j])?a[j]():a[j]));I s.6s("&").1o(/%20/g,"+")}});D.17.1l({1N:H(c,b){I c?7.2g({1Z:"1N",2h:"1N",1y:"1N"},c,b):7.1E(":1G").P(H(){7.V.18=7.5D||"";G(D.1g(7,"18")=="2F"){J a=D("<"+7.2j+" />").6P("1c");7.V.18=a.1g("18");G(7.V.18=="2F")7.V.18="3I";a.21()}}).3l()},1M:H(b,a){I b?7.2g({1Z:"1M",2h:"1M",1y:"1M"},b,a):7.1E(":4j").P(H(){7.5D=7.5D||D.1g(7,"18");7.V.18="2F"}).3l()},78:D.17.2m,2m:H(a,b){I D.1D(a)&&D.1D(b)?7.78.1w(7,19):a?7.2g({1Z:"2m",2h:"2m",1y:"2m"},a,b):7.P(H(){D(7)[D(7).3F(":1G")?"1N":"1M"]()})},9G:H(b,a){I 7.2g({1Z:"1N"},b,a)},9F:H(b,a){I 7.2g({1Z:"1M"},b,a)},9E:H(b,a){I 7.2g({1Z:"2m"},b,a)},9D:H(b,a){I 7.2g({1y:"1N"},b,a)},9M:H(b,a){I 7.2g({1y:"1M"},b,a)},9C:H(c,a,b){I 7.2g({1y:a},c,b)},2g:H(k,j,i,g){J h=D.77(j,i,g);I 7[h.36===Q?"P":"36"](H(){G(7.16!=1)I Q;J f=D.1l({},h),p,1G=D(7).3F(":1G"),46=7;R(p 1n k){G(k[p]=="1M"&&1G||k[p]=="1N"&&!1G)I f.1J.1k(7);G(p=="1Z"||p=="2h"){f.18=D.1g(7,"18");f.33=7.V.33}}G(f.33!=U)7.V.33="1G";f.45=D.1l({},k);D.P(k,H(c,a){J e=2B D.28(46,f,c);G(/2m|1N|1M/.11(a))e[a=="2m"?1G?"1N":"1M":a](k);N{J b=a.6r().1I(/^([+-]=)?([\\d+-.]+)(.*)$/),2b=e.1t(M)||0;G(b){J d=3d(b[2]),2M=b[3]||"2X";G(2M!="2X"){46.V[c]=(d||1)+2M;2b=((d||1)/e.1t(M))*2b;46.V[c]=2b+2M}G(b[1])d=((b[1]=="-="?-1:1)*d)+2b;e.3G(2b,d,2M)}N e.3G(2b,a,"")}});I M})},36:H(a,b){G(D.1D(a)||(a&&a.1q==2p)){b=a;a="28"}G(!a||(1j a=="23"&&!b))I A(7[0],a);I 7.P(H(){G(b.1q==2p)A(7,a,b);N{A(7,a).1p(b);G(A(7,a).K==1)b.1k(7)}})},9X:H(b,c){J a=D.3O;G(b)7.36([]);7.P(H(){R(J i=a.K-1;i>=0;i--)G(a[i].T==7){G(c)a[i](M);a.7n(i,1)}});G(!c)7.5A();I 7}});J A=H(b,c,a){G(b){c=c||"28";J q=D.L(b,c+"36");G(!q||a)q=D.L(b,c+"36",D.2d(a))}I q};D.17.5A=H(a){a=a||"28";I 7.P(H(){J q=A(7,a);q.4s();G(q.K)q[0].1k(7)})};D.1l({77:H(b,a,c){J d=b&&b.1q==a0?b:{1J:c||!c&&a||D.1D(b)&&b,2u:b,41:c&&a||a&&a.1q!=9t&&a};d.2u=(d.2u&&d.2u.1q==4L?d.2u:D.28.5K[d.2u])||D.28.5K.74;d.5M=d.1J;d.1J=H(){G(d.36!==Q)D(7).5A();G(D.1D(d.5M))d.5M.1k(7)};I d},41:{73:H(p,n,b,a){I b+a*p},5P:H(p,n,b,a){I((-29.9r(p*29.9q)/2)+0.5)*a+b}},3O:[],48:U,28:H(b,c,a){7.15=c;7.T=b;7.1i=a;G(!c.3Z)c.3Z={}}});D.28.44={4D:H(){G(7.15.2Y)7.15.2Y.1k(7.T,7.1z,7);(D.28.2Y[7.1i]||D.28.2Y.4w)(7);G(7.1i=="1Z"||7.1i=="2h")7.T.V.18="3I"},1t:H(a){G(7.T[7.1i]!=U&&7.T.V[7.1i]==U)I 7.T[7.1i];J r=3d(D.1g(7.T,7.1i,a));I r&&r>-9p?r:3d(D.2a(7.T,7.1i))||0},3G:H(c,b,d){7.5V=1z();7.2b=c;7.3l=b;7.2M=d||7.2M||"2X";7.1z=7.2b;7.2S=7.4N=0;7.4D();J e=7;H t(a){I e.2Y(a)}t.T=7.T;D.3O.1p(t);G(D.48==U){D.48=4I(H(){J a=D.3O;R(J i=0;i<a.K;i++)G(!a[i]())a.7n(i--,1);G(!a.K){7k(D.48);D.48=U}},13)}},1N:H(){7.15.3Z[7.1i]=D.1K(7.T.V,7.1i);7.15.1N=M;7.3G(0,7.1t());G(7.1i=="2h"||7.1i=="1Z")7.T.V[7.1i]="9m";D(7.T).1N()},1M:H(){7.15.3Z[7.1i]=D.1K(7.T.V,7.1i);7.15.1M=M;7.3G(7.1t(),0)},2Y:H(a){J t=1z();G(a||t>7.15.2u+7.5V){7.1z=7.3l;7.2S=7.4N=1;7.4D();7.15.45[7.1i]=M;J b=M;R(J i 1n 7.15.45)G(7.15.45[i]!==M)b=Q;G(b){G(7.15.18!=U){7.T.V.33=7.15.33;7.T.V.18=7.15.18;G(D.1g(7.T,"18")=="2F")7.T.V.18="3I"}G(7.15.1M)7.T.V.18="2F";G(7.15.1M||7.15.1N)R(J p 1n 7.15.45)D.1K(7.T.V,p,7.15.3Z[p])}G(b)7.15.1J.1k(7.T);I Q}N{J n=t-7.5V;7.4N=n/7.15.2u;7.2S=D.41[7.15.41||(D.41.5P?"5P":"73")](7.4N,n,0,1,7.15.2u);7.1z=7.2b+((7.3l-7.2b)*7.2S);7.4D()}I M}};D.1l(D.28,{5K:{9l:9j,9i:7e,74:9g},2Y:{2e:H(a){a.T.2e=a.1z},2c:H(a){a.T.2c=a.1z},1y:H(a){D.1K(a.T.V,"1y",a.1z)},4w:H(a){a.T.V[a.1i]=a.1z+a.2M}}});D.17.2i=H(){J b=0,1S=0,T=7[0],3q;G(T)ao(D.14){J d=T.1d,4a=T,1s=T.1s,1Q=T.2z,5U=2k&&3r(5B)<9c&&!/9a/i.11(v),1g=D.2a,3c=1g(T,"30")=="3c";G(T.7y){J c=T.7y();1e(c.1A+29.2f(1Q.1C.2e,1Q.1c.2e),c.1S+29.2f(1Q.1C.2c,1Q.1c.2c));1e(-1Q.1C.6b,-1Q.1C.6a)}N{1e(T.5X,T.5W);1B(1s){1e(1s.5X,1s.5W);G(42&&!/^t(98|d|h)$/i.11(1s.2j)||2k&&!5U)2C(1s);G(!3c&&1g(1s,"30")=="3c")3c=M;4a=/^1c$/i.11(1s.2j)?4a:1s;1s=1s.1s}1B(d&&d.2j&&!/^1c|2K$/i.11(d.2j)){G(!/^96|1T.*$/i.11(1g(d,"18")))1e(-d.2e,-d.2c);G(42&&1g(d,"33")!="4j")2C(d);d=d.1d}G((5U&&(3c||1g(4a,"30")=="5x"))||(42&&1g(4a,"30")!="5x"))1e(-1Q.1c.5X,-1Q.1c.5W);G(3c)1e(29.2f(1Q.1C.2e,1Q.1c.2e),29.2f(1Q.1C.2c,1Q.1c.2c))}3q={1S:1S,1A:b}}H 2C(a){1e(D.2a(a,"6V",M),D.2a(a,"6U",M))}H 1e(l,t){b+=3r(l,10)||0;1S+=3r(t,10)||0}I 3q};D.17.1l({30:H(){J a=0,1S=0,3q;G(7[0]){J b=7.1s(),2i=7.2i(),4c=/^1c|2K$/i.11(b[0].2j)?{1S:0,1A:0}:b.2i();2i.1S-=25(7,\'94\');2i.1A-=25(7,\'aF\');4c.1S+=25(b,\'6U\');4c.1A+=25(b,\'6V\');3q={1S:2i.1S-4c.1S,1A:2i.1A-4c.1A}}I 3q},1s:H(){J a=7[0].1s;1B(a&&(!/^1c|2K$/i.11(a.2j)&&D.1g(a,\'30\')==\'93\'))a=a.1s;I D(a)}});D.P([\'5e\',\'5G\'],H(i,b){J c=\'4y\'+b;D.17[c]=H(a){G(!7[0])I;I a!=12?7.P(H(){7==1b||7==S?1b.92(!i?a:D(1b).2e(),i?a:D(1b).2c()):7[c]=a}):7[0]==1b||7[0]==S?46[i?\'aI\':\'aJ\']||D.71&&S.1C[c]||S.1c[c]:7[0][c]}});D.P(["6N","4b"],H(i,b){J c=i?"5e":"5G",4f=i?"6k":"6i";D.17["5s"+b]=H(){I 7[b.3y()]()+25(7,"57"+c)+25(7,"57"+4f)};D.17["90"+b]=H(a){I 7["5s"+b]()+25(7,"2C"+c+"4b")+25(7,"2C"+4f+"4b")+(a?25(7,"6S"+c)+25(7,"6S"+4f):0)}})})();',62,669,'|||||||this|||||||||||||||||||||||||||||||||||if|function|return|var|length|data|true|else|type|each|false|for|document|elem|null|style|event||nodeName|||test|undefined||browser|options|nodeType|fn|display|arguments|url|window|body|parentNode|add|msie|css|indexOf|prop|typeof|call|extend|script|in|replace|push|constructor|text|offsetParent|cur|status|div|apply|firstChild|opacity|now|left|while|documentElement|isFunction|filter|className|hidden|handle|match|complete|attr|ret|hide|show|dataType|trigger|doc|split|top|table|try|catch|success|break|cache|height||remove|tbody|string|guid|num|global|ready|fx|Math|curCSS|start|scrollTop|makeArray|scrollLeft|max|animate|width|offset|tagName|safari|map|toggle||done|Array|find|toUpperCase|button|special|duration|id|copy|value|handler|ownerDocument|select|new|border|exec|stack|none|opera|nextSibling|pushStack|target|html|inArray|unit|xml|bind|GET|isReady|merge|pos|timeout|delete|one|selected|px|step|jsre|position|async|preventDefault|overflow|name|which|queue|removeChild|namespace|insertBefore|nth|removeData|fixed|parseFloat|error|readyState|multiFilter|createElement|rl|re|trim|end|_|param|first|get|results|parseInt|slice|childNodes|encodeURIComponent|append|events|elems|toLowerCase|json|readyList|setTimeout|grep|mouseenter|color|is|custom|getElementsByTagName|block|stopPropagation|addEventListener|callee|proxy|mouseleave|timers|defaultView|password|disabled|last|has|appendChild|form|domManip|props|ajax|orig|set|easing|mozilla|load|prototype|curAnim|self|charCode|timerId|object|offsetChild|Width|parentOffset|src|unbind|br|currentStyle|clean|float|visible|relatedTarget|previousSibling|handlers|isXMLDoc|on|setup|nodeIndex|unique|shift|javascript|child|RegExp|_default|deep|scroll|lastModified|teardown|setRequestHeader|timeStamp|update|empty|tr|getAttribute|innerHTML|setInterval|checked|fromElement|Number|jQuery|state|active|jsonp|accepts|application|dir|input|responseText|click|styleSheets|unload|not|lastToggle|outline|mouseout|getPropertyValue|mouseover|getComputedStyle|bindReady|String|padding|pageX|metaKey|keyCode|getWH|andSelf|clientX|Left|all|visibility|container|index|init|triggered|removeAttribute|classFilter|prevObject|submit|file|after|windowData|inner|client|globalEval|sibling|jquery|absolute|clone|wrapAll|dequeue|version|triggerHandler|oldblock|ctrlKey|createTextNode|Top|handleError|getResponseHeader|parsererror|speeds|checkbox|old|00|radio|swing|href|Modified|ifModified|lastChild|safari2|startTime|offsetTop|offsetLeft|username|location|ajaxSettings|getElementById|isSimple|values|selectedIndex|runtimeStyle|rsLeft|_load|loaded|DOMContentLoaded|clientTop|clientLeft|toElement|srcElement|val|pageY|POST|unshift|Bottom|clientY|Right|fix|exclusive|detachEvent|cloneNode|removeEventListener|swap|toString|join|attachEvent|eval|substr|head|parse|textarea|reset|image|zoom|odd|even|before|prepend|exclude|expr|quickClass|quickID|uuid|quickChild|continue|Height|textContent|appendTo|contents|open|margin|evalScript|borderTopWidth|borderLeftWidth|parent|httpData|setArray|CSS1Compat|compatMode|boxModel|cssFloat|linear|def|webkit|nodeValue|speed|_toggle|eq|100|replaceWith|304|concat|200|alpha|Last|httpNotModified|getAttributeNode|httpSuccess|clearInterval|abort|beforeSend|splice|styleFloat|throw|colgroup|XMLHttpRequest|ActiveXObject|scriptCharset|callback|fieldset|multiple|processData|getBoundingClientRect|contentType|link|ajaxSend|ajaxSuccess|ajaxError|col|ajaxComplete|ajaxStop|ajaxStart|serializeArray|notmodified|keypress|keydown|change|mouseup|mousedown|dblclick|focus|blur|stylesheet|hasClass|rel|doScroll|black|hover|solid|cancelBubble|returnValue|wheelDelta|view|round|shiftKey|resize|screenY|screenX|relatedNode|mousemove|prevValue|originalTarget|offsetHeight|keyup|newValue|offsetWidth|eventPhase|detail|currentTarget|cancelable|bubbles|attrName|attrChange|altKey|originalEvent|charAt|0n|substring|animated|header|noConflict|line|enabled|innerText|contains|only|weight|font|gt|lt|uFFFF|u0128|size|417|Boolean|Date|toggleClass|removeClass|addClass|removeAttr|replaceAll|insertAfter|prependTo|wrap|contentWindow|contentDocument|iframe|children|siblings|prevAll|wrapInner|nextAll|outer|prev|scrollTo|static|marginTop|next|inline|parents|able|cellSpacing|adobeair|cellspacing|522|maxLength|maxlength|readOnly|400|readonly|fast|600|class|slow|1px|htmlFor|reverse|10000|PI|cos|compatible|Function|setData|ie|ra|it|rv|getData|userAgent|navigator|fadeTo|fadeIn|slideToggle|slideUp|slideDown|ig|responseXML|content|1223|NaN|fadeOut|300|protocol|send|setAttribute|option|dataFilter|cssText|changed|be|Accept|stop|With|Requested|Object|can|GMT|property|1970|Jan|01|Thu|Since|If|Type|Content|XMLHTTP|th|Microsoft|td|onreadystatechange|onload|cap|charset|colg|host|tfoot|specified|with|1_|thead|leg|plain|attributes|opt|embed|urlencoded|www|area|hr|ajaxSetup|meta|post|getJSON|getScript|marginLeft|img|elements|pageYOffset|pageXOffset|abbr|serialize|pixelLeft'.split('|'),0,{}))
\ No newline at end of file
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/static/js/kiwipycon.js	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,11 @@
+$(function() {
+
+    // Message ################################################################ 
+
+    var message = $.cookie("message");
+    
+    if (message != null) { 
+        $.jGrowl(message);
+        $.cookie("message", null, { path: '/' });
+    };
+});
Binary file project/static/pdf/Kiwi PyCon Media Statement 2.pdf has changed
Binary file project/static/pdf/Kiwi PyCon Media Statement.pdf has changed
Binary file project/static/pdf/Kiwi PyCon Preconference Release.pdf has changed
Binary file project/static/pdf/KiwiPyCon09_Sponsorship_Brochure_v1.0.pdf has changed
Binary file project/static/pdf/KiwiPyCon09_Sponsorship_Brochure_v1.1.pdf has changed
Binary file project/static/pdf/KiwiPyConCfP.pdf has changed
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/404.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,11 @@
+{% extends "base.html" %}
+
+{% block title %}404 Page Not Found{% endblock %}
+
+{% block content %}
+
+<h1>404 Page Not Found</h1>
+
+<p>Are you sure you have the correct URL?</p>
+
+{% endblock content %}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/500.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,12 @@
+{% extends "base.html" %}
+
+{% block title %}500 Server Error{% endblock %}
+
+{% block content %}
+
+<h1>500 Server Error</h1>
+
+<p>Oops. Something went wrong. Djangonauts behind this site received an information about this
+accident and will start investigation shortly. We apologize for any inconvenience!</p>
+
+{% endblock content %}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/_errors.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,2 @@
+{% if messages %}<div id="messages">{% for message in messages %}{{ message }}{% endfor %}</div>{% endif %}
+{% if form.errors %}<div id="errors">Please correct the errors below</div>{% endif %}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/_menu.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,47 @@
+<div id="left-inner">
+  <ul>
+    <li><a href="/submit-registration/">Registration</a></li>
+    <li>
+      <a href="/talks-cfp/">Talks & CfP</a>
+      <ul>
+        <li><a href="/talks-cfp/schedule/">Conference Schedule</a></li>
+        <li><a href="/talks/">Talks</a></li>
+      </ul>
+    </li>
+    <li>
+      About
+      <ul>
+        <li><a href="/about/accommodation/">Accommodation</a></li>
+        <li><a href="/about/food/">Food</a></li>
+        <li><a href="/about/venue/">The Venue</a></li>
+        <li><a href="/about/reaching/">Reaching the venue</a></li>
+      </ul>
+    </li>
+    <li><a href="/">Blog</a></li>
+    <!--<li><a href="/sponsorship/">Sponsorship</a></li>
+    <li><a href="/media/">Media</a></li>-->
+    {% if user.is_staff %}
+    <li><a href="/howto/">HowTo</a></li>
+    {% endif %}<!--
+    <li>Follow us:<br /><br />
+	  <a href="http://twitter.com/scipy.in" 
+	    target="_blank"
+	    title="Follow us on Twitter"><img src="/img/twitter.png" /></a>
+	</li>
+    <li>
+	  <a href="http://www.flickr.com/search/?q=scipy.in" 
+	    target="_blank"
+	    title="Flickr"><img src="/img/flickr.png" /></a>
+	</li>
+    <li>
+	  <a href="http://www.slideshare.net/tag/scipy.in" 
+	    target="_blank"
+	    title="SlideShare"><img src="/img/slideshare.png" /></a>
+    </li>
+    <li>
+	  <a href="http://scipy.in.blip.tv/"
+	    target="_blank"
+	    title="blip.tv"><img src="/img/bliptv.gif" /></a>
+	</li>-->
+  </ul>
+</div>
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/_menu_user.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,19 @@
+<div id="menu-user">
+    {% if user.is_authenticated %}
+        {% if user.get_full_name %}
+        <strong>{{ user.get_full_name }} &lt;{{ user.username }}&gt;</strong>
+        {% else %}
+            <strong>{{ user.username }}</strong>
+        {% endif %} |
+
+        <a href="{% url kiwipycon_account %}">My profile</a> |
+
+        {% if user.is_superuser %}
+                <a href="/admin/">Administer</a> |
+        {% endif %}
+
+        <a href="{% url kiwipycon_logout %}">Logout</a>
+    {% else %}
+        <a href="{% url kiwipycon_login %}">Login</a>
+    {% endif %}
+</div>
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/_sponsors.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,14 @@
+<div id="right-inner">
+  <h2>Organizers</h2>
+<p><ul>
+  <li>(co-chair) <a href='https://cirl.berkeley.edu/view/User/JarrodMillman'>Jarrod Millman</a>, Neuroscience Institute, UC Berkeley (USA)</li>
+  <li>(co-chair) <a href='http://www.aero.iitb.ac.in/~prabhu'>Prabhu Ramachandran</a>, Department of Aerospace Engineering,
+IIT Bombay (India)</li>
+  <li><a href="http://www.ignouonline.ac.in/sakshat/">National Mission On Education through ICT</a> - Ministry of Human Resource Development, Govt. of India</li>
+  <li><a href='http://fossee.in/'>FOSSEE Team</a></li>
+  <li><a href='http://space-kerala.org/'>SPACE-Kerala (India)</a></li>
+  <li><a href='http://www.itmission.kerala.gov.in'>Kerala State IT Mission(KSITM)</a></li>
+  <li><a href='http://csi-india.org'>SIG-FOSS Of CSI</a></li>
+</ul></p>
+  
+</div>
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/about/accommodation.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,4 @@
+{% extends "base.html" %}
+{% block content %}
+<h1>We will update this page once we have more information on it.</h1>
+{% endblock content %}
\ No newline at end of file
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/about/food.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,4 @@
+{% extends "base.html" %}
+{% block content %}
+<h1>We will update this page once we have more information on it.</h1>
+{% endblock content %}
\ No newline at end of file
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/about/reaching.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,4 @@
+{% extends "base.html" %}
+{% block content %}
+<h1>We will update this page once we have more information on it.</h1>
+{% endblock content %}
\ No newline at end of file
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/about/venue.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,4 @@
+{% extends "base.html" %}
+{% block content %}
+<h1>We will update this page once we have more information on it.</h1>
+{% endblock content %}
\ No newline at end of file
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/admin/base_site.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,10 @@
+{% extends "admin/base.html" %}
+{% load i18n %}
+
+{% block title %}{{ title }} | {% trans 'SciPy.in 2009 Administration' %}{% endblock %}
+
+{% block branding %}
+<h1 id="site-name">{% trans 'SciPy.in 2009 Administration' %}</h1>
+{% endblock %}
+
+{% block nav-global %}{% endblock %}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/base.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,57 @@
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml" lang="en-us" xml:lang="en-us" >
+<head>
+  <meta http-equiv="content-type" content="text/html; charset=utf-8"/>
+  <title>{% block title %}{% endblock %} SciPy.in 2009, December 12 - 17, 2009, Trivandrum, Kerala, India</title>
+
+  <link rel="stylesheet" type="text/css" href="/jquery/jquery.jgrowl.css" />
+  <link rel="stylesheet" type="text/css" href="/css/styles-20090826.css" />
+
+  <script type="text/javascript" src="/jquery/jquery.pack.js"></script>
+  <script type="text/javascript" src="/jquery/jquery.jgrowl_minimized.js"></script>
+  <script type="text/javascript" src="/jquery/jquery.cookie.pack.js"></script>
+  <script type="text/javascript" src="/js/kiwipycon.js"></script>
+
+  <link rel="icon" href="/img/favicon.ico" type="image/x-icon" />
+
+  <link rel="alternate" type="application/rss+xml" title="RSS 2.0" href="/feeds/blog/" />
+
+</head>
+<body>
+
+<div id="logo">
+  <a href="/"><img src="/img/scipyshiny_small.png"
+    alt="SciPy.in Logo" title="SciPy.in Logo"
+    width="139" height="130" /></a>
+</div>
+
+<div id="header">
+  <h1>{% block header %}SciPy.in 2009</h1><h3>December 12 - 17</h3><h3>Kerala, India{% endblock %}</h3>
+  {% include '_menu_user.html' %}
+</div>
+
+<div id="wrapper">
+  <div id="left">
+  {% include '_menu.html' %}
+  </div>
+  <div id="content">
+  {% if user.is_authenticated %}
+      {% include 'user/_usermenu.html' %}
+  {% endif %}
+
+    {% block content %}{% endblock %}
+  </div>
+  <div id="right">
+  {% include '_sponsors.html' %}
+  </div>
+</div>
+
+<div id="footer">
+   <p rel="credits">Content by the <a href="/about/team/" alt="SciPy.in Team">SciPy.in Team</a>,
+   website by <a href="http://bitbucket.org/vshivak/kiwipycon/src/tip/AUTHORS" alt="Website's Creators">Kiwi Djangonauts</a>,
+   hosting by <a href="http://fosse.in/" alt="Free and Open Source software in Science and Engineering Education">Free and Open Source software in Science and Engineering Education</a>,
+   <!-- TODO: logo design by Jason Nielsen--></p>
+</div>
+
+</body>
+</html>
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/blog/post_detail.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,77 @@
+{% extends "blog/base_blog.html" %}
+
+
+{% block title %}{{ object.title }}{% endblock %}
+{% block body_class %}{{ block.super }} post_detail{% endblock %}
+{% block body_id %}post_{{ object.id }}{% endblock %}
+
+
+{% block content_title %}
+  <h2>{{ object.title }}</h2>
+  <p class="other_posts">
+    {% if object.get_previous_by_publish %}
+    <a class="previous" href="{{ object.get_previous_post.get_absolute_url }}">&laquo; {{ object.get_previous_post }}</a>
+    {% endif %}
+    {% if object.get_next_by_publish %}
+    | <a class="next" href="{{ object.get_next_post.get_absolute_url }}">{{ object.get_next_post }} &raquo;</a> 
+    {% endif %}
+  </p>
+{% endblock %}
+
+
+{% block content %}
+  {% load blog markup comments tagging_tags %}
+  
+  <h1>{{ object.title }}</h1>
+  <p class="date">{{ object.publish|date:"j F Y" }}</p>
+  
+  <div class="body">
+    {{ object.body|markdown:"safe" }}
+  </div>
+  
+  {% tags_for_object object as tag_list %}
+  {% if tag_list %}
+  <p class="inline_tag_list"><strong>Related tags:</strong>
+    {% for tag in tag_list %}
+    {{ tag }}{% if not forloop.last %}, {% endif %}
+    {% endfor %}
+  </p>
+  {% endif %}
+  
+  {% get_comment_list for object as comment_list %}
+  {% if comment_list %}
+  <div id="comments">
+    <a name="comments"></a>
+    <h3 class="comments_title">Comments</h3>
+    {% for comment in comment_list %}
+      {% if comment.is_public %}
+      <div class="comment">
+        <h5 class="name">
+          <a name="c{{ comment.id }}" href="{{ comment.get_absolute_url }}" title="Permalink to {{ comment.person_name }}'s comment" class="count">{{ forloop.counter }}</a> 
+          {% if comment.user_url %}<a href="{{ comment.user_url }}">{{ comment.user_name }}</a>{% else %}{{ comment.user_name }}{% endif %} says...
+        </h5>
+        {{ comment.comment|urlizetrunc:"60"|markdown:"safe" }}
+        <p class="date">Posted at {{ comment.submit_date|date:"P" }} on {{ comment.submit_date|date:"F j, Y" }}</p>
+      </div>
+      {% endif %}
+    {% endfor %}
+  </div>
+  {% endif %}
+  {% if user.is_authenticated %}
+    {% if object.allow_comments %}
+      <div id="comment_form">
+      {% render_comment_form for object %}
+    </div>
+    {% else %}
+      <div id="comment_form">
+        <h3>Comments are closed.</h3>
+        <p>Comments have been close for this post.</p>
+      </div>
+    {% endif %}
+  {% else %}
+    <div id="comment_form">
+      <h3>Comments are closed.</h3>
+      <p>Please login in to comment.</p>
+    </div>
+  {% endif %}
+{% endblock %}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/blog/post_list.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,35 @@
+{% extends "blog/base_blog.html" %}
+
+
+{% block title %}{% endblock %}
+{% block body_class %}{{ block.super }} post_list{% endblock %}
+
+
+{% block content_title %}
+  <h2>Post archive</h2>
+{% endblock %}
+
+
+{% block content %}
+  <div class="post_list">
+    {% for post in object_list %}
+    <div>
+      <h3 class="title"><a href="{{ post.get_absolute_url }}">{{ post.title }}</a></h3>
+      <p class="date">{{ post.publish|date:"Y F d" }}</p>
+      <p class="tease">{{ post.tease }}</p>
+    </div>
+    {% endfor %}
+  </div>
+
+  {% if is_paginated %}
+  <p class="pagination">
+    {% if has_next %}
+    <a class="older" href="?page={{ next }}">Older</a>
+    {% endif %}
+    {% if has_next and has_previous %} | {% endif %}
+    {% if has_previous %}
+    <a class="newer" href="?page={{ previous }}">Newer</a>
+    {% endif %}
+  </p>
+  {% endif %}
+{% endblock %}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/comments/form.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,20 @@
+{% load comments %}
+<h3>Comments</h3>
+<form action="{% comment_form_target %}" method="POST">
+  {% for field in form %}
+    {% if field.is_hidden %}
+      {{ field }}
+    {% else %}
+      <p
+        {% if field.errors %} class="error"{% endif %}
+        {% ifequal field.name "honeypot" %} style="display:none;"{% endifequal %}>
+        {% if field.errors %}{{ field.errors }}{% endif %}
+        {{ field.label_tag }} {{ field }}
+      </p>
+    {% endif %}
+  {% endfor %}
+  <p class="submit">
+    <input type="submit" name="submit" class="submit-post" value="Post" />
+    <input type="submit" name="submit" class="submit-preview" value="Preview" />
+  </p>
+</form>
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/flatpages/default.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,9 @@
+{% extends "base.html" %}
+
+{% block title %}
+{{ flatpage.title }}
+{% endblock %}
+
+{% block content %}
+{{ flatpage.content }}
+{% endblock %}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/flatpages/markdown.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,10 @@
+{% extends "base.html" %}
+
+{% load markup %}
+{% block title %}
+{{ flatpage.title }}
+{% endblock %}
+
+{% block content %}
+{{ flatpage.content|markdown }}
+{% endblock %}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/flatpages/restructuredtext.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,10 @@
+{% extends "base.html" %}
+
+{% load markup %}
+{% block title %}
+{{ flatpage.title }}
+{% endblock %}
+
+{% block content %}
+{{ flatpage.content|restructuredtext }}
+{% endblock %}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/flatpages/textile.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,10 @@
+{% extends "base.html" %}
+
+{% load markup %}
+{% block title %}
+{{ flatpage.title }}
+{% endblock %}
+
+{% block content %}
+{{ flatpage.content|textile }}
+{% endblock %}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/notifications/activate_mail.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,35 @@
+Hello everyone,
+  We have not activated your account till now since were still in the
+process of finalizing the ideas for SciPy.in 2009 and the smoothing out
+the organization details. This mail is an activation mail. Click on the
+link below to activate your account.
+
+http://scipy.in/accounts/activate/{{ activation_key }}/
+
+  If your email client doesn't support clicking the links, please copy
+paste the above URL in your browser's address bar. If your email client
+wraps the line and the activation URL is broken, then your activation
+can be constructed as follows:
+
+http://scipy.in/accounts/activate/<your-activation-key>/
+
+Your activation key being:
+{{ activation_key }}
+
+NOTE: Please activate your account within next 7 days i.e, before
+October 26th, 2009. Otherwise your account will be removed from
+our database.
+
+Very important: The registration process is not complete yet. Once you
+activate your account you will be able to login on the site. Please login
+and click on the registration link at the left panel again. You will be
+presented with other details. Please fill in the relevant details. This
+information is very much required for us to conduct SciPy very smoothly.
+
+Optionally you can also click on Edit Profile link at the top and fill in
+your bio.
+
+
+--
+ Thanks for understanding,
+ FOSSEE Team
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/registration/download-csv.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,41 @@
+{% extends "admin/base_site.html" %}
+
+{% block title %}Download Registrations{% endblock %}
+
+{% block content %}
+<h1>Edit Registration</h1>
+
+{% include '_errors.html' %}
+
+<form action=""
+      method="post">
+    <fieldset>
+        <legend>Select Registrations</legend>
+        <table class="kiwipycon-default">
+            {{ form }}
+        </table>
+        <button class="button left"
+                type="submit">
+            Submit
+        </button>
+    </fieldset>
+</form>
+
+{% if no_results %}
+<p>{{ no_results }}</p>
+{% endif %}
+{% if results %}
+<table>
+{% for reg in results %}
+<tr>
+    <td>{{reg.registrant.get_full_name }}</td>
+    <td>{{reg.registrant.email }}</td>
+    <td>{{reg.amount }}</td>
+    <td>{{reg.payment }}</td>
+    <td>{{reg.party }}</td>
+</tr>
+{% endfor %}
+</table>
+{% endif %}
+{% endblock content %}
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/registration/edit-registration.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,24 @@
+{% extends "base.html" %}
+
+{% block title %}Edit Registration{% endblock %}
+
+{% block content %}
+<h1>Edit Registration</h1>
+
+{% include '_errors.html' %}
+
+<form action="{% url kiwipycon_edit_registration id %}"
+      method="post">
+    <fieldset>
+        <legend>Edit Registration</legend>
+        <table class="kiwipycon-default">
+            {{ form }}
+        </table>
+        <button class="button left"
+                type="submit">
+            Save Changes
+        </button>
+    </fieldset>
+</form>
+{% endblock content %}
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/registration/invoice.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,141 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" 
+    "http://www.w3.org/TR/html4/loose.dtd">
+<html>
+<head>
+</head>
+<body>
+<!-- TODO: Replace all New Zealand specific things in this file -->
+<table cellpadding="0" cellspacing="0" width="800px">
+  <tr>
+    <td>
+  <!--  TODO(get an ICON) -->
+  <img src="http://scipy.org/images/scipylogo.gif"
+    alt="SciPy.in Logo" title="SciPy.in Logo"
+    width="72" />
+<br /><br />
+  </td>
+  <td align="right">
+      41 Hihitahi Rise<br />
+      Te Haumi, Paihia 0200<br />
+      Incorporated Society #2250349<br />
+  </td>
+</tr>
+</table>
+<table cellpadding="0" cellspacing="0" width="800px">
+<tr>
+  <td>
+    <h1>New Zealand Python Users Group Incorporated</h1>
+  </td>
+</tr>
+<tr>
+  <td>
+    <hr />
+    <table cellpadding="0" cellspacing="0" width="800px">
+      <tr>
+        <td>Invoice Number: {{ registration.slug }}</td> 
+        <td align="right">
+          Date: {{ registration.submitted|date:"d F, Y"}}</td> 
+      </tr>
+    </table>
+    <hr />
+  </td>
+</tr>
+<tr>
+  <td>
+    <br />
+    <br />
+    To:<br />
+    {{ user.get_profile.fullname }}<br />
+    {{ user.email }}<br />
+    < {{ user.username }} ><br />
+  </td>
+</tr>
+<tr>
+  <td>
+    <br />
+    <br />
+  </td>
+</tr>
+<tr>
+  <td>
+    <table cellpadding="0" cellspacing="0" width="800px">
+      <tr>
+        <th align="left">Item</th> 
+        <th align="right">Price</th> 
+        <th align="right">Qty</th> 
+        <th align="right">Amount (NZ$)</th> 
+      </tr>
+      <tr>
+        <td colspan="4"><hr /></td>
+      </tr>
+      <tr>
+        <td>NZPycon 2009 Attendence fee</td> 
+        <td align="right">{{ registration.amount }}.00</td> 
+        <td align="right">1</td> 
+        <td align="right">{{ registration.amount }}.00</td> 
+      </tr>
+      <tr>
+        <td colspan="4"><hr /></td>
+      </tr>
+      <tr>
+        <td colspan="3"><strong>Total</strong></td>
+        <td align="right"><strong>${{ registration.amount }}.00</strong></td>
+      </tr>
+    </table>
+  </td>
+</tr>
+<tr>
+  <td>
+    <br />
+    <br />
+  </td>
+</tr>
+    {% if registration.sponsor %}
+<tr>
+  <td>
+    As a guest of {{ registration.sponsor|title }} please ignore this invoice.
+  </td>
+</tr>
+    {% endif %}
+    {% if registration.discount %}
+<tr>
+  <td>
+    Your fee has been discounted because you are a student or otherwise on a
+    low income. You will be required to present your Student ID or a Community
+    Services Card on arrival.
+  </td>
+</tr>
+    {% endif %}
+    {% ifequal registration.amount 10 %}
+<tr>
+  <td>
+    Your fee has been discounted because you are a presenter at NZPycon 2009. 
+  </td>
+</tr>
+    {% endifequal %}
+<tr>
+  <td><strong>Thanks for your registration!</strong>
+</tr>
+<tr>
+  <td align="right">
+    <br />
+    {% if registration.payment %}
+    {% if registration.sponsor %}
+      <strong>Thank you, no payment required</strong>
+    {% else %}
+      <strong>Thank you, this invoice has been paid</strong>
+    {% endif %}
+    {% else %}
+    <strong>Please pay to:</strong><br />
+New Zealand Python User Group<br />
+06-0158-0360348-00<br />
+The National Bank<br />
+Auckland University Branch<br />
+PO Box 2132<br />
+    {% endif %}
+  </td>
+</tr>
+</table>
+</body>
+</html>
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/registration/registrations.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,37 @@
+{% extends "base.html" %}
+
+{% block title %}
+Registrations
+{% endblock %}
+
+{% block content %}
+
+<h1>Submit Registration</h1>
+
+    {% if over_reg %}
+    <div class="notice">
+      We have already reached the total number of registrations for the
+      conference.  If you would like to be put on a waiting list in the event
+      that someone can't make it to the conference, please follow the link
+      below to register and we will be in contact if a registration spot comes
+      available.
+    </div>
+    {% endif %}
+
+<p>Currently <strong>{{ registrations }}</strong> persons have registered to attend Kiwi PyCon 2009.</p>
+
+<p>To attend Kiwi Pycon 2009 please <a href="/submit-registration/">register</a></p>
+
+<p>Registration payments:
+
+<pre class="plain">
+New Zealand Python User Group,
+06-0158-0360348-00
+The National Bank,
+Auckland University Branch
+PO Box 2132
+</pre>
+
+Please use your username and invoice number as references when making payments.
+
+{% endblock %}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/registration/submit-registration.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,106 @@
+{% extends "base.html" %}
+
+{% block title %}Submit Registration{% endblock %}
+
+{% block content %}
+
+    <h1>Submit Registration</h1>
+
+    {% if over_reg %}
+    <div class="notice">
+      We have already reached the total number of registrations for the
+      conference. If you would like to be put on a waiting list in the event that
+      someone can't make it to the conference, please register below and we
+      will be in contact if a registration spot comes available. <strong>N.B. Do not
+      pay the admission fee.</strong>
+    </div>
+    {% endif %}
+        <form action="/submit-registration/"
+              method="post">
+    {% if not user.is_authenticated %}
+                <fieldset>
+                    <legend>Have you already registered for the conference?</legend>
+                    <table class="kiwipycon-default">
+                        {{ login_form }}
+                    </table>
+
+                <input type="hidden"
+                       name="action"
+                       value="login" />
+
+            <button class="button left"
+                    type="submit">
+                Login
+            </button>
+                </fieldset>
+
+        </form>
+    {% endif %}
+
+    <p></p>
+
+    {% if not user.is_authenticated %}
+        <br />
+        <form action="/submit-registration/"
+              enctype="multipart/form-data"
+              method="post">
+                <fieldset>
+                    <legend>Registrant Details</legend>
+                    <table class="kiwipycon-default required">
+                        {{ registrant_form }}
+                    </table>
+
+                <input type="hidden"
+                       name="action"
+                       value="register" />
+                </fieldset>
+    {% endif %}
+                <br />
+
+{% if registration_form.errors %}<div class="errors">Please correct the errors below</div>{% endif %}
+
+                <fieldset>
+                    <legend>Details</legend>
+                    <table class="kiwipycon-default required">
+                        {% for field in registration_form.personal_fields %}
+                        <tr class="{% cycle odd,even %}"><th>{{ field.label_tag }}</th>
+                          <td>{{ field.errors }}{{ field }}<br />{{ field.help_text }} </td></tr>
+                         {% endfor %}
+
+                        {% for field in registration_form.other_fields %}
+                        <tr class="{% cycle odd,even %}"><th>{{ field.label_tag }}</th>
+                          <td>{{ field.errors }}{{ field }}<br />{{ field.help_text }} </td></tr>
+                         {% endfor %}
+
+                    </table>
+                  </fieldset>
+
+                <br />
+
+                <fieldset>
+                    <legend>Demographics</legend>
+                    <table class="kiwipycon-default required">
+                        {% for field in registration_form.demographic_fields %}
+                        <tr class="{% cycle odd,even %}"><th>{{ field.label_tag }}</th>
+                          <td>{{ field.errors }}{{ field }}<br />{{ field.help_text }} </td></tr>
+                         {% endfor %}
+                    </table>
+                </fieldset>
+                <fieldset>
+                    <legend>Others</legend>
+                    <table class="kiwipycon-default">
+                         {{ wifi_form }}
+                    </table>
+
+                <button class="button left"
+                        type="submit">
+                    Submit Registration
+                </button>
+                </fieldset>                
+        </form>
+    {% if message %}
+    <script type="text/javascript">
+        $.jGrowl("{{ message }}");
+</script>
+    {% endif %}
+{% endblock content %}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/sponsor/schwag.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,26 @@
+{% extends "base.html" %}
+<!-- TODO: Replace sentences with PR's suggestions. -->
+{% block title %}
+Schwag Sponsors
+{% endblock %}
+
+{% block content %}
+    <h1>Schwag Sponsors</h1>
+
+<p>The SciPy.in 2009 Organising Committee would also like to thank the
+following organisations for their generous contributions of giveaway items for
+the SciPy.in PyCon attendees!</p>
+
+<p><ul>
+  <li>(co-chair) <a href='https://cirl.berkeley.edu/view/User/JarrodMillman'>Jarrod Millman</a>, Neuroscience Institute, UC Berkeley (USA)</li>
+  <li>(co-chair) <a href='http://www.aero.iitb.ac.in/~prabhu'>Prabhu Ramachandran</a>, Department of Aerospace Engineering,
+IIT Bombay (India)</li>
+  <li>Vimal Joseph, <a href='http://space-kerala.org/'>SPACE-Kerala (India)</a></li>
+  <li><a href='http://fossee.in/'>FOSSEE Team</a></li>
+  <li><a href='http://www.itmission.kerala.gov.in'>Kerala State IT Mission(KSITM)</a></li>
+  <li><a href='http://csi-india.org'>SIG-FOSS Of CSI</a></li>
+</ul></p>
+
+
+{% endblock %}
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/talk/edit-talk.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,23 @@
+{% extends "base.html" %}
+
+{% block title %}Edit Talk{% endblock %}
+
+{% block content %}
+<h1>Edit Talk</h1>
+
+{% include '_errors.html' %}
+<form action="{% url kiwipycon_edit_talk id %}"
+      method="post">
+    <fieldset>
+        <legend>Edit Talk</legend>
+        <table class="kiwipycon-default">
+            {{ form }}
+        </table>
+        <button class="button left"
+                type="submit">
+            Save Changes
+        </button>
+    </fieldset>
+</form>
+{% endblock content %}
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/talk/schedule.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,22 @@
+{% extends "base.html" %}
+{% block content %}
+<div class="post">
+  <div class="title">
+    <h2><a name="date">Dates</a></h2>
+  </div>
+  <div class="entry">
+    <p>Its a 6-day programme between December 12 - 17, 2009, comprising of 2 days of conference, 2 days of tutorials with 2 parallel tracks (one specifically for teachers and the other for the general
+public), and 2 days of Sprints.</p>
+    <table cellspacing="5">
+      <tr> <td align=center>Date</td><td>Activity</td> </tr>
+      <tr > <td align=right>Saturday, Dec. 12 2009</td><td>Conference</td> </tr>
+      <tr> <td align=right>Sunday, Dec. 13 2009</td><td>Conference</td> </tr>
+      <tr> <td align=right>Monday, Dec. 14 2009</td><td>Tutorials</td> </tr>
+      <tr> <td align=right>Tuesday, Dec. 15 2009</td><td>Tutorials</td> </tr>
+      <tr> <td align=right>Wednesday, Dec. 16 2009</td><td>Sprint</td> </tr>
+      <tr> <td align=right>Thursday, Dec. 17 2009</td><td>Sprint</td> </tr>
+    </table>
+  </div>
+<h3>Details of the programme will be updated soon.</h3>
+</div>
+{% endblock content %}
\ No newline at end of file
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/talk/submit-talk.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,63 @@
+{% extends "base.html" %}
+
+{% block title %}Submit Talk Proposal{% endblock %}
+
+{% block content %}
+    <h1>Submit Talk Proposal</h1>
+
+{% include '_errors.html' %}
+
+        <form action="{% url kiwipycon_submit_talk %}"
+              method="post">
+    {% if not user.is_authenticated %}
+                <fieldset>
+                    <legend>Are you a member of this site?</legend>
+                    <table class="kiwipycon-default required">
+                        {{ login_form }}
+                    </table>
+
+                <input type="hidden"
+                       name="action"
+                       value="login" />
+
+            <button class="button left"
+                    type="submit">
+                Login
+            </button>
+                </fieldset>
+
+        </form>
+        <br />
+        <form action="{% url kiwipycon_submit_talk %}"
+              enctype="multipart/form-data"
+              method="post">
+                <fieldset>
+                    <legend>Speaker Registration</legend>
+                    <table class="kiwipycon-default required">
+                        {{ register_form }}
+                    </table>
+
+                <input type="hidden"
+                       name="action"
+                       value="register" />
+                </fieldset>
+    {% endif %}
+                <br />
+                <fieldset>
+                    <legend>Talk Submission</legend>
+                    <table class="kiwipycon-default required">
+                        {{ talk_form }}
+                    </table>
+
+                <button class="button left"
+                        type="submit">
+                    Submit Talk
+                </button>
+                </fieldset>
+        </form>
+    {% if message %}
+    <script type="text/javascript">
+        $.jGrowl("{{ message }}");
+</script>
+    {% endif %}
+{% endblock content %}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/talk/talk_detail.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,43 @@
+{% extends "base.html" %}
+
+{% block title %}{{ object.title }}{% endblock %}
+
+{% block content %}
+<h1>{{ object.title }}</h1>
+<p><a href="/talks/">View all talks</a></p>
+
+<style>
+dl.default dt {
+    font-weight: bold;
+}
+dl.default dd {
+    margin-bottom: 1em;
+}
+</style>
+
+<dl class="default">
+    <dt>Title</dt>
+    <dd>{{ object.title }}</dd>
+    <dt>Speaker</dt>
+    <dd>{{ object.speaker.get_profile.fullname }}</dd>
+    <dt>Speaker's profile</dt>
+    <dd>{{ object.speaker.get_profile.about }}</dd>
+    <dt>Topic</dt>
+    <dd>{{ object.topic }}</dd>
+    <dt>Abstract</dt>
+    <dd>{{ object.abstract }}</dd>
+    <dt>Outline</dt>
+    <dd>{{ object.outline }}</dd>
+    <dt>Audience</dt>
+    {% load talk_extras %}
+    {% with choices|choice:object.audience as audience %}
+    <dd>{{ audience|title }}</dd>
+    {% endwith %}
+    <dt>Tags</dt>
+    <dd>{{ object.tags }}</dd>
+</dl>
+
+</ul>
+{% endblock content %}
+
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/talk/talk_list.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,22 @@
+{% extends "base.html" %}
+
+{% block title %}Talk Listing{% endblock %}
+
+{% block content %}
+<h1>Talks</h1>
+<h3>Accepted talks list is not out yet. This page will be updated soon.</h3>
+<p><strong>Showing {{ count }} of {{ count }}</strong></p>
+
+<ul class="plain">
+{% for object in object_list %}
+<li>
+  <ul class="plain" style="margin-bottom:1em;">
+      <li><a href="/talks/talk/{{object.id }}/">{{ object.title }}</a></li>
+      <li><strong>{{ object.speaker.get_profile.fullname }}</strong></li>
+      <li>{{ object.abstract }}</li>
+  </ul>
+</li>
+{% endfor %}
+</ul>
+{% endblock content %}
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/talk/talks-cfp.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,33 @@
+{% extends "base.html" %}
+{% block content %}
+<div class="section" id="call-for-papers">
+<h1>Call for Papers</h1>
+<p>We welcome contributions from the academic world as well as the industry. 
+We look forward to your submissions on the use of Python for scientific 
+computing and education.  This includes pedagogy,  exploration, modeling and 
+analysis from both applied and developmental perspectives.</p>
+<div class="section" id="submission-of-papers">
+<h2>Submission of Papers</h2>
+<p>If you wish to present, please submit an abstract of between
+300 and 700 words should describe the topic and motivate its
+relevance to scientific computing.  Depending on the number
+and quality of submissions, the conference organizers will
+allot between 10-30 minutes for all accepted talks.</p>
+<p>In addition, there will be an open session for lightning talks
+during which any attendee willing to do so is invited to do a
+couple-of-minutes-long presentation.</p>
+<p>If you wish to present a talk at the conference, please follow 
+the guidelines below.</p>
+</div>
+<div class="section" id="submission-guidelines">
+<h2>Submission Guidelines</h2>
+<ul class="simple">
+<li>Submissions should be uploaded via <a href="{% url kiwipycon_submit_talk %}">the web form.</a></li>
+<li>Submissions whose main purpose is to promote a commercial product or
+service will be refused.</li>
+<li>All accepted proposals must be presented at the SciPy conference by
+at least one author.</li>
+</ul>
+</div>
+</div>
+{% endblock content %}
\ No newline at end of file
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/user/_usermenu.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,16 @@
+<div class="right">
+    <ul class="horizontal-menu">
+        <li>
+            <a href="{% url kiwipycon_account %}">My Profile</a>
+        </li>
+        <li>
+            <a href="{% url kiwipycon_edit_profile %}">Edit Profile</a>
+        </li>
+        <li>
+            <a href="{% url kiwipycon_password %}">Change Password</a>
+        </li>
+        <li>
+            <a href="{% url kiwipycon_username %}">Change Username</a>
+        </li>
+    </ul>
+</div>
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/user/account.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,119 @@
+{% extends "base.html" %}
+          <li class="last"><a
+            href="mailto:kauaerangastore@xtra.co.nz">kauaerangastore@xtra.co.nz</a></li>
+<!-- TODO: Lot of fees related and New Zealand group related info. -->
+{% block title %}My Profile{% endblock %}
+
+{% block content %}
+<h1>My Profile: {{ user.first_name }} {{user.last_name}}</h1>
+
+<table class="kiwipycon-default">
+    <tr>
+        <td class="label">
+            Username:
+        </td>
+        <td>
+          {{ user.username }}
+        </td>
+    </tr>
+    <tr>
+        <td class="label">
+            Name:
+        </td>
+        <td>
+        {% if user.first_name %}
+            <span>{{ user.get_full_name }}</span>
+        {% else %}
+        <span class="important">No name, please <a 
+            href="{% url kiwipycon_edit_profile %}">edit profile</a>.</span>
+        {% endif %}
+        </td>
+        <td rowspan="4">
+        <div class="picture">
+          <img src="{{ photo }}" width="80" height="80" />
+        </div>
+        </td>
+    </tr>
+    <tr>
+        <td class="label">
+            Email:
+        </td>
+        <td>
+            <a href="mailto:{{ user.email }}">{{ user.email }}</a>
+        </td>
+    </tr>
+    <tr>
+        <td class="label">
+          Url:
+        </td>
+        <td>
+            <a href="{{ profile.url }}" target="_blank">{{ profile.url }}</a>
+        </td>
+    </tr>
+    <tr>
+        <td class="label">
+          About:
+        </td>
+        <td style="width: 40em">
+          {{ profile.about }}
+        </td>
+    </tr>
+</table>
+{% if comment %}
+<strong>{{ comment }}</strong>
+{% endif %}
+{% if form %}
+<!-- wifi form -->
+  <h2>Wifi</h2>
+<p>The following form will help the SciPy.in team identify wireless
+requirements.</p> 
+<form action="" method="post">
+<table>
+  {{ form }}
+</table>
+<input type="submit" value="submit" />
+</form>
+{% endif %}
+{% if registration %}
+<div id="talks">
+  <h2>Your Registration</h2>
+<p>
+  <a href="/edit-registration/{{ registration.id }}/"
+    title="Edit">Edit Registration</a>
+  {% if registration.sponsor %}
+  {% else %}
+  | <a href="/invoice/"
+    title="Your invoice (html)">Your invoice (html)</a> (<a href="/pdf_invoice/"
+    title="Your invoice (pdf)">pdf</a>)</p>
+  {% endif %}
+  </p>
+</div>
+{% endif %}
+{% if talks %}
+<div id="talks">
+  <h2>Your Submitted Talks</h2>
+  <table class="kiwipycon-default" border="1">
+    <th>Title</th>
+    <th>Duration</th>
+    <th>Audience</th>
+    <th>Tags</th>
+    <th>&nbsp;</th>
+{% for talk in talks %}
+<tr>
+<td>{{ talk.title }}</td>
+<td>{{ talk.duration }}</td>
+<td>{{ talk.audience }}</td>
+<td>{{ talk.tags }}</td>
+<td>
+        {% if talk.approved %}
+          <span>Accepted</span>
+        {% else %}
+          <a href="/edit-talk/{{ talk.id }}/" title="Edit">Edit</a>
+        {% endif %}
+</td>
+</tr>
+{% endfor %}
+</table>
+</div>
+{% endif %}
+{% endblock content %}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/user/editprofile.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,28 @@
+{% extends "base.html" %}
+
+{% block title %}Edit Your Profile{% endblock %}
+
+{% block content %}
+    <h1>Edit Your Profile</h1>
+
+
+    <form action="{% url kiwipycon_edit_profile %}"
+          enctype="multipart/form-data"
+          method="post">
+                <fieldset>
+                    <legend>Edit Profile</legend>
+                    <table class="kiwipycon-default">
+                        {{ form }}
+                    </table>
+                    <input type="hidden"
+                           name="action"
+                           value="email" />
+        
+                    <input class="button left"
+                           type="submit"
+                           value="Save Changes" />
+        
+    </fieldset>
+    </form>
+{% endblock %}
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/user/login.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,73 @@
+{% extends "base.html" %}
+
+{% block title %}Login or Register{% endblock %}
+
+{% block content %}
+<h1>Login or Register</h1>
+
+    <div class="login">
+        <h2 class="authenticate">Login</h2>
+
+        <div class="description">
+            Log in for registered users of the site.
+        </div>
+
+        <form class="authenticate"
+              enctype="multipart/form-data"
+              action="{% url kiwipycon_login %}"
+              method="post">
+
+                <table class="kiwipycon-default">
+                    {{ login_form }}
+                    <tr>
+                        <td></td>
+                        <td>
+                            <a href="{% url kiwipycon_password_reset %}">Forgot password?</a>
+                        </td>
+                    </tr>
+                </table>
+
+            <input type="hidden"
+                   name="action"
+                   value="login" />
+
+            <input type="hidden"
+                   name="next"
+                   value="{{ next_url }}" />
+
+            <button class="button left"
+                    type="submit">
+                Login
+            </button>
+
+        </form>
+    </div>
+
+    <div class="register">
+        <h2 class="authenticate">Register</h2>
+
+        <div class="description">
+            If you are not already a member of the site you can register here.
+        </div>
+
+        <form action="{% url kiwipycon_login %}"
+              method="post">
+                    <table class="kiwipycon-default">
+                        {{ register_form }}
+                    </table>
+                <input type="hidden"
+                       name="action"
+                       value="register" />
+
+                <input type="hidden"
+                       name="next"
+                       value="{{ next_url }}" />
+
+                <button class="button left"
+                        type="submit">
+                    Register
+                </button>
+        </form>
+    </div>
+{% endblock content %}
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/user/password.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,56 @@
+{% extends "base.html" %}
+
+{% block title %}Change Your Password{% endblock %}
+
+
+{% block content %}
+
+    <h1>Change Your Password</h1>
+
+    <p>
+        Please enter your old password, for security's sake, and then enter your new password twice so we can verify you typed it in correctly.
+    </p>
+
+    <form action="{% url kiwipycon_password %}" 
+          method="post">
+            <table class="kiwipycon-default">
+                <tr>
+                    <td class="label">
+                        <label for="id_old_password">Old password:</label>
+                    </td>
+                    <td>
+                        {{ form.old_password.errors }}                        
+                        {{ form.old_password }}
+                    </td>
+                </tr>
+                <tr>
+                    <td class="label">
+                        <label for="id_new_password1">New password:</label>
+                    </td>
+                    <td>
+                        {{ form.new_password1.errors }}
+                        {{ form.new_password1 }}
+                    </td>
+                </tr>
+                <tr>
+                    <td class="label">
+                        <label for="id_new_password2">Confirm password:</label>
+                    </td>
+                    <td>
+                        {{ form.new_password2.errors }}
+                        {{ form.new_password2 }}
+                    </td>
+                </tr>
+                <tr>
+                    <td></td>
+                    <td>
+                        <input class="button left" type="submit" value="Change password" />
+                    </td>                    
+                </tr>
+            </table>
+        
+        </table>  
+    </form>
+
+{% endblock %}
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/templates/user/username.html	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,32 @@
+{% extends "base.html" %}
+
+{% block title %}Change Your Username{% endblock %}
+
+{% block content %}
+    <h1>Change your username</h1>
+
+    <form action="{% url kiwipycon_username %}"
+          method="post">
+        <table class="kiwipycon-default">
+            <tr>
+                  <td class="label">
+                      <label for="id_username">New username:</label>
+                  </td>
+                  <td>
+                      {{ form.username.errors }}                        
+                      {{ form.username }}
+                  </td>
+            </tr>
+            <tr>
+                <td></td>
+                <td>
+                    <input class="button left"
+                           type="submit"
+                           value="Save username" />
+                </td>
+            </tr>
+        </table>
+        
+    </form>
+{% endblock %}
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project/urls.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,92 @@
+#django
+from django.conf.urls.defaults import include
+from django.conf.urls.defaults import patterns
+from django.conf import settings
+from django.contrib import admin
+from django.views.generic.simple import direct_to_template
+from django.conf.urls.defaults import *
+
+#basic.blog
+from basic.blog.feeds import BlogPostsFeed
+
+feeds = {
+    'blog': BlogPostsFeed,
+    }
+
+admin.autodiscover()
+
+# Blog & Admin
+urlpatterns = patterns(
+    '',
+    (r'', include('basic.blog.urls')),
+    (r'^feeds/(?P<url>.*)/$', 'django.contrib.syndication.views.feed', {'feed_dict': feeds}),
+    (r'^comments/', include('django.contrib.comments.urls')),
+    (r'^admin/(.*)', admin.site.root),
+)
+
+# Talks, etc.
+urlpatterns += patterns('project.kiwipycon.talk.views',
+    url(r'^talks/$',  'list_talks', name='list_talks'),
+    url(r'^talks/talk/(?P<id>\d+)/$',  'talk', name='talk_detail'),
+    url(r'^submit-talk/$',  'submit_talk', name='kiwipycon_submit_talk'),
+    url(r'^edit-talk/(?P<id>\d+)/$',  'edit_talk', name='kiwipycon_edit_talk'),
+    )
+
+# Registration
+urlpatterns += patterns('project.kiwipycon.registration.views',
+    url(r'^invoice/$',  'invoice', name='kiwipycon_invoice'),
+    url(r'^pdf_invoice/$',  'pdf_invoice', name='kiwipycon_pdf_invoice'),
+    url(r'^registrations/$',  'registrations', name='kiwipycon_registrations'),
+    url(r'^submit-registration/$',  'submit_registration', name='kiwipycon_submit_registration'),
+    url(r'^edit-registration/(?P<id>\d+)/$',  'edit_registration',
+        name='kiwipycon_edit_registration'),
+    url(r'^download_csv/', 'download_csv', name="download_csv"),
+    )
+
+
+# Authentication and Profile
+urlpatterns += patterns('project.kiwipycon.user.views',
+    url(r'^login/$',  'login', name='kiwipycon_login'),
+    url(r'^logout/$',  'logout', name='kiwipycon_logout'),
+    url(r'^account/$',  'account', name='kiwipycon_account'),
+    url(r'^password/$', 'password', name='kiwipycon_password'), # change pwd
+    url(r'^username/$', 'username', name='kiwipycon_username'), # change uname
+    url(r'^edit-profile/$', 'edit_profile', name='kiwipycon_edit_profile'),
+    )
+
+# About pages and all other static html pages
+urlpatterns += patterns('',
+    url(r'^about/accommodation/$', 
+        direct_to_template, {"template": "about/accommodation.html"},
+        name='accommodation'),
+    url(r'^about/food/$',
+        direct_to_template, {"template": "about/food.html"}, name='food'),
+    url(r'^about/venue/$',
+        direct_to_template, {"template": "about/venue.html"}, name='venue'),
+    url(r'^about/reaching/$', 
+        direct_to_template, {"template": "about/reaching.html"},
+        name='reaching'),
+    url(r'^talks-cfp/$', 
+        direct_to_template, {"template": "talk/talks-cfp.html"},
+        name='reaching'),
+    url(r'^talks-cfp/schedule/$', 
+        direct_to_template, {"template": "talk/schedule.html"},
+        name='reaching')
+    )
+
+# Password reset
+urlpatterns += patterns('django.contrib.auth.views',
+     url(r'^password-reset/$', 'password_reset', name='kiwipycon_password_reset'),
+     url(r'^password-reset-done/$', 'password_reset_done'),
+     url(r'^password-reset-confirm/(?P<uidb36>[-\w]*)/(?P<token>[-\w]*)$', 'password_reset_confirm'),
+     url(r'^password-reset-complete/$', 'password_reset_complete'),
+)
+
+# Serve static files in DEBUG = True mode
+if settings.DEBUG:
+    urlpatterns += patterns('',
+        (r'^media/(?P<path>.*)$', 'django.views.static.serve',
+         {'document_root': settings.MEDIA_ROOT}),
+        (r'^(?P<path>.*)$', 'django.views.static.serve',
+         {'document_root': settings.STATIC_ROOT}),
+    )
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/scripts/scipy_migrate.py	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,32 @@
+"""Helper script to send an email to all users who registered
+before activation logic was implemented. This script can be 
+run only within a Django shell.
+"""
+
+
+__authors__ = [
+  '"Madhusudan.C.S" <madhusudancs@gmail.com>',
+  ]
+
+
+from datetime import datetime
+
+from django.template import loader
+
+from registration.models import RegistrationProfile
+
+
+def remind_users():
+    regs = RegistrationProfile.objects.filter(
+        user__is_active=0,
+        user__date_joined__lte=datetime(2009, 10, 13))
+
+    template = 'notifications/activate_mail.html'
+
+    for reg in regs:
+
+        subject = "Update and activate your SciPy.in registration."
+        message = loader.render_to_string(template, dictionary={'activation_key': reg.activation_key})
+
+        reg.user.email_user(subject=subject, message=message)
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/sponsor.sql	Fri Oct 30 15:09:12 2009 +0530
@@ -0,0 +1,14 @@
+INSERT INTO "sponsor_sponsor" VALUES(1,'canonical','Canonical Limited','gold','http://www.canonical.com/','*','*','*','canonical.png',5);
+INSERT INTO "sponsor_sponsor" VALUES(2,'catalyst','Catalyst IT Liimited','gold','http://catalyst.net.nz/','*','*','*','catalyst.png',5);
+INSERT INTO "sponsor_sponsor" VALUES(3,'weta-digital','Weta Digital Limited','gold','http://www.wetafx.co.nz/','*','*','*','weta.jpg',5);
+INSERT INTO "sponsor_sponsor" VALUES(4,'psf','Python Software Foundation','gold','http://www.python.org/psf/','*','*','*','psf.png',5);
+INSERT INTO "sponsor_sponsor" VALUES(5,'unfold','Unfold Limited','gold','http://www.unfold.co.nz/','*','*','*','unfold.png',5);
+INSERT INTO "sponsor_sponsor" VALUES(6,'tait','Tait Radio Communications','gold','http://www.tait.co.nz/','*','*','*','tait.png',5);
+INSERT INTO "sponsor_sponsor" VALUES(7,'encode','Encode Limited','silver','http://encode.net.nz/','*','*','*','encode.png',2);
+INSERT INTO "sponsor_sponsor" VALUES(8,'powerhouse-ventures','powerHouse Ventures Limited','silver','http://www.powerhouse-ventures.co.nz/','*','*','*','powerhouse.png',2);
+INSERT INTO "sponsor_sponsor" VALUES(9,'pretaweb','PretaWeb','silver','http://www.pretaweb.com/','*','*','*','pretaweb.png',2);
+INSERT INTO "sponsor_sponsor" VALUES(10,'vortexdna','VortexDNA','silver','http://www.vortexdna.com/','*','*','*','vortex.png',2);
+INSERT INTO "sponsor_sponsor" VALUES(11,'apress','Apress','schwag','http://apress.com/','*','*','*','apress.png',0);
+INSERT INTO "sponsor_sponsor" VALUES(12,'oreilly','O''Reilly','schwag','http://www.oreilly.com/','*','*','*','oreilly.png',0);
+INSERT INTO "sponsor_sponsor" VALUES(13,'webstock','Webstock','schwag','http://www.webstock.org.nz/','*','*','*','webstock.png',0);
+INSERT INTO "sponsor_sponsor" VALUES(14,'packt','Packt Publishing','schwag','http://www.packtpub.com/','*','*','*','packt.png',0);