2016-07-02 15:58:50 +02:00
|
|
|
from django.db import models
|
|
|
|
from django import forms
|
|
|
|
from django.forms import ModelForm
|
|
|
|
|
|
|
|
from users.models import User
|
|
|
|
|
|
|
|
class Facture(models.Model):
|
|
|
|
user = models.ForeignKey('users.User', on_delete=models.PROTECT)
|
|
|
|
paiement = models.ForeignKey('Paiement', on_delete=models.PROTECT)
|
2016-07-02 17:58:04 +02:00
|
|
|
banque = models.ForeignKey('Banque', on_delete=models.PROTECT, blank=True, null=True)
|
|
|
|
cheque = models.CharField(max_length=255, blank=True)
|
2016-07-02 15:58:50 +02:00
|
|
|
number = models.IntegerField()
|
|
|
|
date = models.DateTimeField(auto_now_add=True)
|
|
|
|
name = models.CharField(max_length=255)
|
|
|
|
prix = models.DecimalField(max_digits=5, decimal_places=2)
|
2016-07-02 18:30:59 +02:00
|
|
|
valid = models.BooleanField(default=True)
|
2016-07-02 15:58:50 +02:00
|
|
|
|
|
|
|
def __str__(self):
|
2016-07-02 18:30:59 +02:00
|
|
|
return str(self.name) + ' ' + str(self.date) + ' ' + str(self.user)
|
2016-07-02 15:58:50 +02:00
|
|
|
|
|
|
|
class Article(models.Model):
|
|
|
|
name = models.CharField(max_length=255)
|
|
|
|
prix = models.DecimalField(max_digits=5, decimal_places=2)
|
2016-07-02 18:30:59 +02:00
|
|
|
cotisation = models.BooleanField()
|
2016-07-02 21:17:21 +02:00
|
|
|
duration = models.IntegerField(help_text="Durée exprimée en mois entiers", blank=True, null=True)
|
2016-07-02 15:58:50 +02:00
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
|
|
|
|
|
|
|
class Banque(models.Model):
|
|
|
|
name = models.CharField(max_length=255)
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
|
|
|
|
|
|
|
class Paiement(models.Model):
|
|
|
|
moyen = models.CharField(max_length=255)
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return self.moyen
|
|
|
|
|
2016-07-02 18:30:59 +02:00
|
|
|
class Cotisation(models.Model):
|
2016-07-04 03:21:25 +02:00
|
|
|
facture = models.OneToOneField('Facture', on_delete=models.PROTECT)
|
2016-07-02 21:17:21 +02:00
|
|
|
date_start = models.DateTimeField()
|
2016-07-02 18:30:59 +02:00
|
|
|
date_end = models.DateTimeField()
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return str(self.facture)
|
|
|
|
|
2016-07-02 15:58:50 +02:00
|
|
|
class NewFactureForm(ModelForm):
|
|
|
|
article = forms.ModelMultipleChoiceField(queryset=Article.objects.all(), label="Article")
|
|
|
|
|
|
|
|
def __init__(self, *args, **kwargs):
|
|
|
|
super(NewFactureForm, self).__init__(*args, **kwargs)
|
|
|
|
self.fields['number'].label = 'Quantité'
|
|
|
|
self.fields['cheque'].required = False
|
|
|
|
self.fields['banque'].required = False
|
|
|
|
self.fields['cheque'].label = 'Numero de chèque'
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
model = Facture
|
2016-07-02 21:17:21 +02:00
|
|
|
exclude = ['user', 'prix', 'name', 'valid']
|
2016-07-02 15:58:50 +02:00
|
|
|
|
|
|
|
class EditFactureForm(ModelForm):
|
|
|
|
def __init__(self, *args, **kwargs):
|
|
|
|
super(EditFactureForm, self).__init__(*args, **kwargs)
|
|
|
|
self.fields['user'].label = 'Adherent'
|
|
|
|
self.fields['number'].label = 'Quantité'
|
|
|
|
self.fields['cheque'].required = False
|
|
|
|
self.fields['banque'].required = False
|
|
|
|
self.fields['cheque'].label = 'Numero de chèque'
|
|
|
|
self.fields['name'].label = 'Designation'
|
|
|
|
self.fields['prix'].label = 'Prix unitaire'
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
model = Facture
|
2016-07-02 17:58:04 +02:00
|
|
|
fields = '__all__'
|