X-Git-Url: http://git.cascardo.eti.br/?p=cascardo%2Feventmanager.git;a=blobdiff_plain;f=views.py;h=6b370ff2d2d914535bc30dccfaa39a804919da24;hp=36ddacabebd50c889df4ae0f573b9f5527da44d1;hb=HEAD;hpb=221f9b712a6b693ac9593b7997fa63263d3e3ae9 diff --git a/views.py b/views.py index 36ddaca..6b370ff 100644 --- a/views.py +++ b/views.py @@ -22,7 +22,9 @@ from django.template import RequestContext, Context, loader from django.contrib.auth.decorators import login_required, user_passes_test from django.contrib.auth.models import Group, User from django.contrib.auth import authenticate, login +from django.contrib.admin.views.decorators import staff_member_required from django.newforms import form_for_instance +from django.core.exceptions import ObjectDoesNotExist from django.core.mail import EmailMessage from django.db import transaction from django.http import get_host @@ -32,6 +34,7 @@ from eventmanager.decorators import enable_login_form from eventmanager.conteudo.models import Noticia, Menu, Secao from eventmanager.eventos.models import * from eventmanager.forms import * +from eventmanager.controllers import * from datetime import datetime import sha @@ -146,7 +149,6 @@ def inscricao_individual(request): ok = False if request.POST and form.is_valid(): cd = form.cleaned_data - group = Group.objects.get_or_create(name='participantes')[0] user = User(username=cd['nome_usuario'], email=cd['email']) @@ -168,6 +170,8 @@ def inscricao_individual(request): p.refbanco = 0 p.telefone = cd['telefone'] p.home_page = cd['home_page'] + p.comercial = cd['inscricao_comercial'] + p.cpf_cnpj = cd['cpf_cnpj'] p.save() u = authenticate(username=cd['nome_usuario'], password=cd['senha']) @@ -208,6 +212,8 @@ def inscricao_caravana(request): p.refbanco = 0 p.telefone = cd['telefone'] p.home_page = cd['home_page'] + p.comercial = False # yeah, always false! + p.cpf_cnpj = '' p.save() c = Caravana() @@ -229,7 +235,7 @@ def inscricao_boleto(request): # dynamic values of the form now = datetime.now() today = datetime.date(now) - first_date = datetime.date(datetime(2007, 10, 12)) + first_date = datetime.date(datetime(2007, 10, 16)) c = {} p = request.user.participante_set.get() @@ -238,7 +244,7 @@ def inscricao_boleto(request): initial = {} if p.refbanco == 0: - # o número refran deve ser gerado a cada novo boleto e deve ser único, + # o número refTran deve ser gerado a cada novo boleto e deve ser único, # mesmo para os testes refs = [x.refbanco for x in Participante.objects.all()] new_ref = len(refs) @@ -252,9 +258,12 @@ def inscricao_boleto(request): new_ref = p.refbanco initial['refTran'] = '1458197%s' % str(new_ref).zfill(10) - if today < first_date: - initial['valor'] = '3500' - initial['dtVenc'] = '12102007' + if today <= first_date: + initial['dtVenc'] = '16102007' + if not p.comercial: + initial['valor'] = '3500' + else: + initial['valor'] = '8000' # caso seja uma caravana... if ca and len(ca.parsed_participantes()) >= 10: @@ -368,26 +377,61 @@ def editar_trabalho(request, codigo): c = {'formulario': form} return build_response(request, 'editar_trabalho.html', c) - @login_required def meus_dados(request): - form = EditarPalestrante(request.POST or None) - palestrante = request.user.palestrante_set.get() - ok = False + try: + entity = request.user.palestrante_set.get() + except Palestrante.DoesNotExist: + entity = request.user.participante_set.get() - for name, field in form.fields.items(): - field.initial = getattr(palestrante, name) + FormKlass = form_for_instance(entity) + # ugly hammer to hide some fields... + del FormKlass.base_fields['usuario'] + + ok = False + form = FormKlass(request.POST or None) if request.POST and form.is_valid(): - cd = form.cleaned_data - for name, field in form.fields.items(): - setattr(palestrante, name, cd[name]) - palestrante.save() + form.save() ok = True - c = {'form': form, 'ok': ok} - return build_response(request, 'editar_palestrante.html', c) + c = {'form': form, 'ok': ok, 'title': entity.__class__.__name__} + return build_response(request, 'editar_usuario.html', c) + +@enable_login_form +def dados_palestrante(request, codigo): + d = {} + try: + d = {'dados_usuario': Palestrante.objects.get(id=codigo)} + except ObjectDoesNotExist: + d = {} + return build_response(request, 'dados_palestrante.html', d) + + +@enable_login_form +def dados_palestra(request, codigo): + try: + d = {'dados_palestra': Trabalho.objects.get(id=codigo)} + except ObjectDoesNotExist: + d = {} + return build_response(request, 'dados_palestra.html',d) + + +@enable_login_form +def programacao(request): + ap = Trabalho.objects.filter(aprovado=True) + ord = ap.order_by('dia', 'time_start', 'room') + d = {'aprovadas': ord} + return build_response(request, 'programacao.html',d) + +@enable_login_form +@staff_member_required +def grade(request): + ap = Trabalho.objects.filter(aprovado=True) + ord = ap.order_by('dia', 'time_start', 'room') + d = {'aprovadas': ord} + return build_response(request, 'grade.html', d) @enable_login_form def chamada_trabalhos(request):