2016-07-02 13:58:50 +00:00
|
|
|
# App de gestion des users pour re2o
|
|
|
|
# Goulven Kermarec, Gabriel Détraz
|
|
|
|
# Gplv2
|
|
|
|
from django.shortcuts import render, redirect
|
|
|
|
from django.shortcuts import render_to_response, get_object_or_404
|
|
|
|
from django.core.context_processors import csrf
|
|
|
|
from django.template import Context, RequestContext, loader
|
2016-07-09 02:12:09 +00:00
|
|
|
from django.contrib.auth.decorators import login_required, permission_required
|
2016-07-02 13:58:50 +00:00
|
|
|
from django.contrib import messages
|
2016-07-06 18:57:31 +00:00
|
|
|
from django.db.models import Max, ProtectedError
|
2016-07-02 13:58:50 +00:00
|
|
|
|
2016-07-11 20:52:55 +00:00
|
|
|
from .models import Facture, Article, Vente, Cotisation, Paiement, Banque
|
2016-07-09 21:26:17 +00:00
|
|
|
from .forms import NewFactureForm, EditFactureForm, ArticleForm, DelArticleForm, PaiementForm, DelPaiementForm, BanqueForm, DelBanqueForm, NewFactureFormPdf
|
2016-07-02 15:58:04 +00:00
|
|
|
from users.models import User
|
2016-07-08 01:27:02 +00:00
|
|
|
from .tex import render_tex
|
2016-07-11 22:05:07 +00:00
|
|
|
from re2o.settings_local import ASSO_NAME, ASSO_ADDRESS_LINE1, ASSO_ADDRESS_LINE2, ASSO_SIRET, ASSO_EMAIL, ASSO_PHONE, LOGO_PATH
|
2016-07-02 13:58:50 +00:00
|
|
|
|
2016-07-02 19:17:21 +00:00
|
|
|
from dateutil.relativedelta import relativedelta
|
2016-07-02 19:32:00 +00:00
|
|
|
from django.utils import timezone
|
2016-07-02 19:17:21 +00:00
|
|
|
|
2016-07-02 13:58:50 +00:00
|
|
|
def form(ctx, template, request):
|
|
|
|
c = ctx
|
|
|
|
c.update(csrf(request))
|
|
|
|
return render_to_response(template, c, context_instance=RequestContext(request))
|
|
|
|
|
2016-07-05 00:22:11 +00:00
|
|
|
def create_cotis(facture, user, duration):
|
2016-07-02 19:17:21 +00:00
|
|
|
""" Update et crée l'objet cotisation associé à une facture, prend en argument l'user, la facture pour la quantitéi, et l'article pour la durée"""
|
|
|
|
cotisation=Cotisation(facture=facture)
|
2016-07-10 02:02:48 +00:00
|
|
|
date_max = user.end_adhesion() or timezone.now()
|
2016-07-02 19:32:00 +00:00
|
|
|
if date_max < timezone.now():
|
|
|
|
datemax = timezone.now()
|
|
|
|
cotisation.date_start=date_max
|
2016-07-05 00:22:11 +00:00
|
|
|
cotisation.date_end = cotisation.date_start + relativedelta(months=duration)
|
2016-07-02 19:17:21 +00:00
|
|
|
cotisation.save()
|
|
|
|
return
|
|
|
|
|
2016-07-08 10:35:53 +00:00
|
|
|
@login_required
|
2016-07-09 15:16:44 +00:00
|
|
|
@permission_required('cableur')
|
2016-07-02 13:58:50 +00:00
|
|
|
def new_facture(request, userid):
|
2016-07-02 15:58:04 +00:00
|
|
|
try:
|
|
|
|
user = User.objects.get(pk=userid)
|
|
|
|
except User.DoesNotExist:
|
|
|
|
messages.error(request, u"Utilisateur inexistant" )
|
|
|
|
return redirect("/cotisations/")
|
|
|
|
facture = Facture(user=user)
|
2016-07-02 13:58:50 +00:00
|
|
|
facture_form = NewFactureForm(request.POST or None, instance=facture)
|
|
|
|
if facture_form.is_valid():
|
2016-07-02 15:58:04 +00:00
|
|
|
new_facture = facture_form.save(commit=False)
|
|
|
|
article = facture_form.cleaned_data['article']
|
|
|
|
new_facture.save()
|
2016-07-11 20:52:55 +00:00
|
|
|
for art in article:
|
|
|
|
new_vente = Vente.objects.create(facture=new_facture, name=art.name, prix=art.prix, cotisation=art.cotisation, duration=art.duration)
|
|
|
|
new_vente.save()
|
2016-07-05 00:22:11 +00:00
|
|
|
if any(art.cotisation for art in article):
|
|
|
|
duration = sum(art.duration*facture.number for art in article if art.cotisation)
|
|
|
|
create_cotis(new_facture, user, duration)
|
2016-07-02 19:17:21 +00:00
|
|
|
messages.success(request, "La cotisation a été prolongée pour l'adhérent %s " % user.name )
|
|
|
|
else:
|
|
|
|
messages.success(request, "La facture a été crée")
|
2016-07-07 11:19:03 +00:00
|
|
|
return redirect("/users/profil/" + userid)
|
2016-07-02 13:58:50 +00:00
|
|
|
return form({'factureform': facture_form}, 'cotisations/facture.html', request)
|
|
|
|
|
2016-07-08 10:35:53 +00:00
|
|
|
@login_required
|
2016-07-11 22:05:07 +00:00
|
|
|
@permission_required('cableur')
|
2016-07-08 01:27:02 +00:00
|
|
|
def new_facture_pdf(request):
|
2016-07-09 21:26:17 +00:00
|
|
|
facture_form = NewFactureFormPdf(request.POST or None)
|
|
|
|
if facture_form.is_valid():
|
|
|
|
tbl = []
|
|
|
|
article = facture_form.cleaned_data['article']
|
|
|
|
quantite = facture_form.cleaned_data['number']
|
|
|
|
paid = facture_form.cleaned_data['paid']
|
|
|
|
destinataire = facture_form.cleaned_data['dest']
|
|
|
|
objet = facture_form.cleaned_data['obj']
|
|
|
|
detail = facture_form.cleaned_data['detail']
|
|
|
|
for a in article:
|
|
|
|
tbl.append([a, quantite, a.prix * quantite])
|
|
|
|
prix_total = sum(a[2] for a in tbl)
|
|
|
|
return render_tex(request, 'cotisations/factures.tex', {'DATE' : timezone.now(),'dest':destinataire, 'obj':objet, 'detail':detail, 'article':tbl, 'total':prix_total, 'paid':paid, 'asso_name':ASSO_NAME, 'line1':ASSO_ADDRESS_LINE1, 'line2':ASSO_ADDRESS_LINE2, 'siret':ASSO_SIRET, 'email':ASSO_EMAIL, 'phone':ASSO_PHONE})
|
|
|
|
return form({'factureform': facture_form}, 'cotisations/facture.html', request)
|
2016-07-08 01:27:02 +00:00
|
|
|
|
2016-07-11 22:05:07 +00:00
|
|
|
@login_required
|
|
|
|
def facture_pdf(request, factureid):
|
|
|
|
try:
|
|
|
|
facture = Facture.objects.get(pk=factureid)
|
|
|
|
except Facture.DoesNotExist:
|
|
|
|
messages.error(request, u"Facture inexistante" )
|
|
|
|
return redirect("/cotisations/")
|
|
|
|
if not request.user.has_perms(('cableur',)) and facture.user != request.user:
|
|
|
|
messages.error(request, "Vous ne pouvez pas afficher une facture ne vous appartenant pas sans droit cableur")
|
|
|
|
return redirect("/users/profil/" + str(request.user.id))
|
|
|
|
vente = Vente.objects.all().filter(facture=facture)
|
|
|
|
ventes = []
|
|
|
|
for v in vente:
|
|
|
|
ventes.append([v, facture.number, v.prix * facture.number])
|
|
|
|
return render_tex(request, 'cotisations/factures.tex', {'paid':True, 'fid':facture.id, 'DATE':facture.date,'dest':facture.user, 'article':ventes, 'total': facture.prix_total(), 'asso_name':ASSO_NAME, 'line1': ASSO_ADDRESS_LINE1, 'line2':ASSO_ADDRESS_LINE2, 'siret':ASSO_SIRET, 'email':ASSO_EMAIL, 'phone':ASSO_PHONE, 'tpl_path':LOGO_PATH})
|
|
|
|
|
2016-07-09 15:16:44 +00:00
|
|
|
@permission_required('cableur')
|
2016-07-02 13:58:50 +00:00
|
|
|
def edit_facture(request, factureid):
|
|
|
|
try:
|
|
|
|
facture = Facture.objects.get(pk=factureid)
|
|
|
|
except Facture.DoesNotExist:
|
|
|
|
messages.error(request, u"Facture inexistante" )
|
|
|
|
return redirect("/cotisations/")
|
|
|
|
facture_form = EditFactureForm(request.POST or None, instance=facture)
|
|
|
|
if facture_form.is_valid():
|
|
|
|
facture_form.save()
|
|
|
|
messages.success(request, "La facture a bien été modifiée")
|
|
|
|
return redirect("/cotisations/")
|
2016-07-02 15:58:04 +00:00
|
|
|
return form({'factureform': facture_form}, 'cotisations/facture.html', request)
|
2016-07-02 13:58:50 +00:00
|
|
|
|
2016-07-08 10:35:53 +00:00
|
|
|
@login_required
|
2016-07-09 02:12:09 +00:00
|
|
|
@permission_required('trésorier')
|
2016-07-06 18:57:31 +00:00
|
|
|
def add_article(request):
|
|
|
|
article = ArticleForm(request.POST or None)
|
|
|
|
if article.is_valid():
|
|
|
|
article.save()
|
|
|
|
messages.success(request, "L'article a été ajouté")
|
2016-07-08 01:27:02 +00:00
|
|
|
return redirect("/cotisations/index_article/")
|
|
|
|
return form({'factureform': article}, 'cotisations/facture.html', request)
|
|
|
|
|
2016-07-08 10:35:53 +00:00
|
|
|
@login_required
|
2016-07-09 02:12:09 +00:00
|
|
|
@permission_required('trésorier')
|
2016-07-08 01:27:02 +00:00
|
|
|
def edit_article(request, articleid):
|
|
|
|
try:
|
|
|
|
article_instance = Article.objects.get(pk=articleid)
|
|
|
|
except Article.DoesNotExist:
|
|
|
|
messages.error(request, u"Entrée inexistante" )
|
|
|
|
return redirect("/cotisations/index_article/")
|
|
|
|
article = ArticleForm(request.POST or None, instance=article_instance)
|
|
|
|
if article.is_valid():
|
|
|
|
article.save()
|
|
|
|
messages.success(request, "Type d'article modifié")
|
|
|
|
return redirect("/cotisations/index_article/")
|
2016-07-06 18:57:31 +00:00
|
|
|
return form({'factureform': article}, 'cotisations/facture.html', request)
|
|
|
|
|
2016-07-08 10:35:53 +00:00
|
|
|
@login_required
|
2016-07-09 02:12:09 +00:00
|
|
|
@permission_required('trésorier')
|
2016-07-06 18:57:31 +00:00
|
|
|
def del_article(request):
|
|
|
|
article = DelArticleForm(request.POST or None)
|
|
|
|
if article.is_valid():
|
|
|
|
article_del = article.cleaned_data['articles']
|
|
|
|
article_del.delete()
|
|
|
|
messages.success(request, "Le/les articles ont été supprimé")
|
2016-07-08 01:27:02 +00:00
|
|
|
return redirect("/cotisations/index_article")
|
2016-07-06 18:57:31 +00:00
|
|
|
return form({'factureform': article}, 'cotisations/facture.html', request)
|
|
|
|
|
2016-07-08 10:35:53 +00:00
|
|
|
@login_required
|
2016-07-09 02:12:09 +00:00
|
|
|
@permission_required('trésorier')
|
2016-07-06 19:43:39 +00:00
|
|
|
def add_paiement(request):
|
|
|
|
paiement = PaiementForm(request.POST or None)
|
|
|
|
if paiement.is_valid():
|
|
|
|
paiement.save()
|
|
|
|
messages.success(request, "Le moyen de paiement a été ajouté")
|
2016-07-08 01:27:02 +00:00
|
|
|
return redirect("/cotisations/index_paiement/")
|
|
|
|
return form({'factureform': paiement}, 'cotisations/facture.html', request)
|
|
|
|
|
2016-07-08 10:35:53 +00:00
|
|
|
@login_required
|
2016-07-09 02:12:09 +00:00
|
|
|
@permission_required('trésorier')
|
2016-07-08 01:27:02 +00:00
|
|
|
def edit_paiement(request, paiementid):
|
|
|
|
try:
|
|
|
|
paiement_instance = Paiement.objects.get(pk=paiementid)
|
|
|
|
except Paiement.DoesNotExist:
|
|
|
|
messages.error(request, u"Entrée inexistante" )
|
|
|
|
return redirect("/cotisations/index_paiement/")
|
|
|
|
paiement = PaiementForm(request.POST or None, instance=paiement_instance)
|
|
|
|
if paiement.is_valid():
|
|
|
|
paiement.save()
|
|
|
|
messages.success(request, "Type de paiement modifié")
|
|
|
|
return redirect("/cotisations/index_paiement/")
|
2016-07-06 19:43:39 +00:00
|
|
|
return form({'factureform': paiement}, 'cotisations/facture.html', request)
|
|
|
|
|
2016-07-08 10:35:53 +00:00
|
|
|
@login_required
|
2016-07-09 02:12:09 +00:00
|
|
|
@permission_required('trésorier')
|
2016-07-06 19:43:39 +00:00
|
|
|
def del_paiement(request):
|
|
|
|
paiement = DelPaiementForm(request.POST or None)
|
|
|
|
if paiement.is_valid():
|
|
|
|
paiement_dels = paiement.cleaned_data['paiements']
|
|
|
|
for paiement_del in paiement_dels:
|
|
|
|
try:
|
|
|
|
paiement_del.delete()
|
|
|
|
messages.success(request, "Le moyen de paiement a été supprimé")
|
|
|
|
except ProtectedError:
|
|
|
|
messages.error(request, "Le moyen de paiement %s est affecté à au moins une facture, vous ne pouvez pas le supprimer" % paiement_del)
|
2016-07-08 01:27:02 +00:00
|
|
|
return redirect("/cotisations/index_paiement/")
|
2016-07-06 19:43:39 +00:00
|
|
|
return form({'factureform': paiement}, 'cotisations/facture.html', request)
|
|
|
|
|
2016-07-08 10:35:53 +00:00
|
|
|
@login_required
|
2016-07-09 15:16:44 +00:00
|
|
|
@permission_required('cableur')
|
2016-07-06 20:20:49 +00:00
|
|
|
def add_banque(request):
|
|
|
|
banque = BanqueForm(request.POST or None)
|
|
|
|
if banque.is_valid():
|
|
|
|
banque.save()
|
|
|
|
messages.success(request, "La banque a été ajoutée")
|
2016-07-08 01:27:02 +00:00
|
|
|
return redirect("/cotisations/index_banque/")
|
|
|
|
return form({'factureform': banque}, 'cotisations/facture.html', request)
|
|
|
|
|
2016-07-08 10:35:53 +00:00
|
|
|
@login_required
|
2016-07-09 02:12:09 +00:00
|
|
|
@permission_required('trésorier')
|
2016-07-08 01:27:02 +00:00
|
|
|
def edit_banque(request, banqueid):
|
|
|
|
try:
|
|
|
|
banque_instance = Article.objects.get(pk=banqueid)
|
|
|
|
except Banque.DoesNotExist:
|
|
|
|
messages.error(request, u"Entrée inexistante" )
|
|
|
|
return redirect("/cotisations/index_banque/")
|
|
|
|
banque = BanqueForm(request.POST or None, instance=banque_instance)
|
|
|
|
if banque.is_valid():
|
|
|
|
banque.save()
|
|
|
|
messages.success(request, "Banque modifiée")
|
|
|
|
return redirect("/cotisations/index_banque/")
|
2016-07-06 20:20:49 +00:00
|
|
|
return form({'factureform': banque}, 'cotisations/facture.html', request)
|
|
|
|
|
2016-07-08 10:35:53 +00:00
|
|
|
@login_required
|
2016-07-09 02:12:09 +00:00
|
|
|
@permission_required('trésorier')
|
2016-07-06 20:20:49 +00:00
|
|
|
def del_banque(request):
|
|
|
|
banque = DelBanqueForm(request.POST or None)
|
|
|
|
if banque.is_valid():
|
|
|
|
banque_dels = banque.cleaned_data['banques']
|
|
|
|
for banque_del in banque_dels:
|
|
|
|
try:
|
|
|
|
banque_del.delete()
|
|
|
|
messages.success(request, "La banque a été supprimée")
|
|
|
|
except ProtectedError:
|
|
|
|
messages.error(request, "La banque %s est affectée à au moins une facture, vous ne pouvez pas la supprimer" % banque_del)
|
2016-07-08 01:27:02 +00:00
|
|
|
return redirect("/cotisations/index_banque/")
|
2016-07-06 20:20:49 +00:00
|
|
|
return form({'factureform': banque}, 'cotisations/facture.html', request)
|
|
|
|
|
2016-07-08 10:35:53 +00:00
|
|
|
@login_required
|
2016-07-09 15:16:44 +00:00
|
|
|
@permission_required('cableur')
|
2016-07-08 01:27:02 +00:00
|
|
|
def index_article(request):
|
|
|
|
article_list = Article.objects.order_by('name')
|
2016-07-10 02:02:48 +00:00
|
|
|
return render(request, 'cotisations/index_article.html', {'article_list':article_list})
|
2016-07-08 01:27:02 +00:00
|
|
|
|
2016-07-08 10:35:53 +00:00
|
|
|
@login_required
|
2016-07-09 15:16:44 +00:00
|
|
|
@permission_required('cableur')
|
2016-07-08 01:27:02 +00:00
|
|
|
def index_paiement(request):
|
|
|
|
paiement_list = Paiement.objects.order_by('moyen')
|
2016-07-10 02:02:48 +00:00
|
|
|
return render(request, 'cotisations/index_paiement.html', {'paiement_list':paiement_list})
|
2016-07-08 01:27:02 +00:00
|
|
|
|
2016-07-08 10:35:53 +00:00
|
|
|
@login_required
|
2016-07-09 15:16:44 +00:00
|
|
|
@permission_required('cableur')
|
2016-07-08 01:27:02 +00:00
|
|
|
def index_banque(request):
|
|
|
|
banque_list = Banque.objects.order_by('name')
|
2016-07-10 02:02:48 +00:00
|
|
|
return render(request, 'cotisations/index_banque.html', {'banque_list':banque_list})
|
2016-07-08 01:27:02 +00:00
|
|
|
|
2016-07-08 10:35:53 +00:00
|
|
|
@login_required
|
2016-07-09 15:16:44 +00:00
|
|
|
@permission_required('cableur')
|
2016-07-02 13:58:50 +00:00
|
|
|
def index(request):
|
2016-07-05 14:19:17 +00:00
|
|
|
facture_list = Facture.objects.order_by('date').reverse()
|
2016-07-10 02:02:48 +00:00
|
|
|
return render(request, 'cotisations/index.html', {'facture_list': facture_list})
|